

# BEST AVAILABLE COPY

(19)日本国特許庁 (JP)

(12)公開特許公報 (A)

(11)特許出願公開番号

特開平8-339325

(43)公開日 平成8年(1996)12月24日

|                                                  |             |                   |                           |                          |
|--------------------------------------------------|-------------|-------------------|---------------------------|--------------------------|
| (51) Int.Cl. <sup>6</sup><br>G06F 12/02<br>9/455 | 識別記号<br>570 | 府内整理番号<br>9189-5B | F I<br>G06F 12/02<br>9/44 | 技術表示箇所<br>570 A<br>310 A |
|--------------------------------------------------|-------------|-------------------|---------------------------|--------------------------|

審査請求 未請求 請求項の数 28 O.L (全28頁)

|                         |                            |
|-------------------------|----------------------------|
| (21)出願番号<br>特願平8-124375 | (22)出願日<br>平成8年(1996)5月20日 |
| (31)優先権主張番号<br>480105   | (32)優先日<br>1995年6月7日       |
| (33)優先権主張国<br>米国(US)    |                            |

|                                                                                                                                             |
|---------------------------------------------------------------------------------------------------------------------------------------------|
| (71)出願人<br>390009531<br>インターナショナル・ビジネス・マシーンズ・コーポレイション<br>INTERNATIONAL BUSINESS MACHINES CORPORATION<br>アメリカ合衆国10504、ニューヨーク州<br>アーモンク(番地なし) |
| (72)発明者<br>ジョン・ダブル・ゴエツ<br>アメリカ合衆国05465、ヴァーモント州<br>ジェリコバターカップ レイン3                                                                           |
| (74)代理人<br>弁理士 合田 潔(外2名)                                                                                                                    |

最終頁に続く

(54)【発明の名称】二つの別個の命令セット・アーキテクチャへの拡張をサポートすることができるアーキテクチャ・モード制御を備えたマイクロプロセッサ

(57)【要約】(修正有)

【課題】一つの多重タスク処理オペレーティング・システムの下で二つの別個のアーキテクチャをサポートするプロセッサを提供する。

【解決手段】マイクロプロセッサは、それが作動するところのアーキテクチャコンテキストを制御するモード制御装置を含み、制御装置は、モード・ビットの制御の下でアドレス変換が生じることを許容し、変換機構を一方のアーキテクチャからもう一方のアーキテクチャに切り換えることができるメモリ管理装置(MMU)を持っている。一つのMMUが、二つの別個のアーキテクチャのアドレスを変換して、命令が適切にデコードされるようになる。MMUはまた、一方のアーキテクチャのアドレス変換を他方のそれに対してマッピングして、両方のアーキテクチャ用に書かれたソフトウェアを一つのオペレーティング・システムの制御の下で多重タスク処理することができるようになる。



## 【特許請求の範囲】

【請求項 1】別個の命令セットおよびメモリ管理方式を有する第一および第二のアーキテクチャをサポートし、一つの多重タスク処理オペレーティング・システムの下で作動するプロセッサにおいて、

前記第一のアーキテクチャの第一の命令セットの命令をデコードし、前記第二のアーキテクチャの第二の命令セットの命令を直接デコードし、前記第一の命令セットのデコードされた命令を前記第二の命令セットの一つ以上の命令に対してマッピングするための命令セット管理手段と、

前記第一および第二のアーキテクチャについて仮想アドレスから実アドレスへのアドレス変換を実行するためのメモリ管理手段と、

メモリから読み出されるプログラムのアーキテクチャ・コンテキストを、前記第一のアーキテクチャのコードまたは前記第二のアーキテクチャのコードのいずれかとして検出し、前記命令セット管理手段および前記メモリ管理手段を制御して、前記第一のアーキテクチャのアドレス変換と第二のアーキテクチャのアドレス変換との間で動的に切り替え、前記第二のアーキテクチャの、一つ以上のマッピングされてデコードされた命令または直接デコードされた命令を実行するための制御手段と、を含むことを特徴とするプロセッサ。

【請求項 2】前記メモリ管理手段が、実効アドレスを仮想アドレスに変換する際に第一または第二のアーキテクチャ変換方法のどちらがメモリ管理装置によって使用されるかを制御するための、前記制御手段によって制御されるモード制御機構を含む請求項 1 記載のプロセッサ。

【請求項 3】前記モード制御機構が前記プロセッサの命令取出しおよびデコード機構を制御して、前記第一および第二のアーキテクチャの命令が、前記命令セット管理手段による適切なデコードのために取り出され、配列されるようにする請求項 2 記載のプロセッサ。

【請求項 4】前記メモリ管理装置が、前記第二のアーキテクチャのページ・テーブル項目からページ・モード制御ビットを読み出し、前記ページ・モード制御ビットが前記制御手段に供給されて、前記メモリ管理手段によるアドレス変換を制御する請求項 3 記載のプロセッサ。

【請求項 5】前記制御手段が、プロセッサがどちらのアーキテクチャ・コンテキストの下で作動するかを制御するためのアーキテクチャ・コンテキスト制御機構であって、実効アドレスを仮想アドレスに変換する際に前記プロセッサの前記メモリ管理装置によって使用されるアーキテクチャ変換方法を制御し、さらに、前記プロセッサの命令取出しおよびデコード論理を制御し、さらに、プロセスおよび構築されたリソースの実行コンテキストを制御し、さらに、前記プロセッサの割込みおよび例外機構を制御するためのアーキテクチャ・コンテキスト制御機構と、

一つのアドレス変換機構が、一方のアーキテクチャのアドレスをもう一方のアーキテクチャのアドレスの変換に対してマッピングすることを許容し、統合された割込みおよび例外機構が、割込みまたは例外が生じた際に実効中のアーキテクチャ・コンテキストにかかわりなく、非同期的な割込みおよびページ変換ならびの保護関連の例外を取り扱うことを許容する拡張および限定を前記二つのアーキテクチャに対して可能にするための修飾モード制御機構と、を含む請求項 1 記載のプロセッサ。

10 【請求項 6】前記命令セット管理手段が、前記第一の命令セットの命令をデコードするための第一のデコード手段と、前記第二の命令セットの命令をデコードするための第二のデコード手段と、前記第一のデコード手段からのデコードされた命令を前記第二の命令セットの一つ以上のデコードされた命令に対してマッピングするためのマッピング手段と、前記マッピング手段からのデコードされた命令または前記第二のデコード手段からのデコードされた命令を選択するための、前記制御手段によって制御される選択手段と、を含む請求項 1 記載のプロセッサ。

【請求項 7】前記第一および第二のデコード手段が前記第一および第二のアーキテクチャの簡単な命令をデコードし、簡単な命令が、基本的な演算クラスの中にマッピングし、一つの実行装置によって取り扱わることができる命令であり、前記命令管理手段がさらに、前記第一の命令セットの複雑な命令をデコードするための第三のデコード手段と、

前記第二の命令セットの複雑な命令をデコードするための第四のデコード手段と、

前記第三または第四のデコード手段からのデコードされた命令を選択するための、前記制御手段によって制御される第二の選択手段と、

前記第三または第四のデコード手段からのデコードされた命令を前記第二の命令セットの多数の簡単な命令に対してマッピングするための、前記第二の選択手段の出力を受ける第二のマッピング手段と、

複雑な命令がデコードされる場合には前記第二のマッピング手段の出力を選択し、簡単な命令がデコードされる

40 場合には前記第一の選択手段の出力を選択するための、前記第三または第四のデコード手段の一方からの有効な信号に応答する第三の選択手段と、をさらに含む請求項 6 記載のプロセッサ。

【請求項 8】前記制御装置が、前記プロセッサ内のレジスタ中に記憶された、前記第二のアーキテクチャのアドレス変換を可能にするか不能にするかを決定する第一のビット、メモリ中の現在のページが前記第一のアーキテクチャのものか前記第二のアーキテクチャのものかを示す第二のビットおよびアーキテクチャ修飾ビットである第三のビットを含む複数のビットの状態に依存して、前

記プロセッサが複数の状態の一つに入るよう制御するモード制御装置を含む請求項1記載のプロセッサ。

【請求項9】前記プロセッサが、主メモリから読み出される命令のページ・モードを検出し、メモリ中の現在のページが前記第一のアーキテクチャのものか前記第二のアーキテクチャのものかを前記第二のビットによって前記モード制御装置に知らせるメモリ管理装置を含む請求項8記載のプロセッサ。

【請求項10】前記モード制御装置が、機能制御レジスタをさらに含み、前記プロセッサの起動またはリセット状態に応答して、前記プロセッサを前記第一および第二のアーキテクチャにそれぞれ対応する前記第一または第二のモードのいずれかで初期化し、その後、前記機能制御レジスタ中のビットの状態がアーキテクチャ・コンテキスト間での動的な切換えを可能にする請求項8記載のプロセッサ。

【請求項11】一つの多重タスク処理オペレーティング・システムの下で作動するプロセッサにおいて具現化される、二つの別個の命令セット・アーキテクチャをサポートする方法であって、

ソフトウェアによって供給されるモード制御ビットに応答して実効アドレスを仮想アドレスに変換する際に第一および第二のアーキテクチャ変換方法のどちらがメモリ管理装置によって使用されるかを制御するステップと、プロセッサの命令取出しおよびデコード機構を制御して、二つの異なるアーキテクチャの命令がソフトウェアによって供給されるモード制御ビットに応答して適切にデコードされるようにするステップと、

一方のアーキテクチャの変換をもう一方のアーキテクチャのそれに対してマッピングすることにより、前記二つの異なるアーキテクチャのアドレスを変換するステップと、

多重タスク処理環境において、一方のアーキテクチャ用に書かれたアプリケーション・ソフトウェアからもう一方のアーキテクチャ用に書かれたアプリケーション・ソフトウェアに切り換えるステップと、を含むことを特徴とする方法。

【請求項12】マイクロプロセッサの割込みおよび例外機構を制御するステップと、

一つのアドレス変換機構が、第一のアーキテクチャのアドレスを第二のアーキテクチャの変換に対してマッピングすることによって第一のアーキテクチャのアドレスを変換することを許容し、統合された割込みおよび例外機構が、割込みまたは例外が生じた際に実効中のアーキテクチャ・コンテキストにかかわりなく、非同期的な割込みおよびページ変換ならびに保護関連の例外を取り扱うことを許容する拡張および限定を前記二つのアーキテクチャに対して可能にするステップと、

命令が実行すべきところのアーキテクチャ・コンテキストを決定するステップと、

をさらに含む請求項11記載のプロセッサにおいて具現化される方法。

【請求項13】二つの別個の命令セット・アーキテクチャをサポートし、一つの多重タスク処理オペレーティング・システムの下で作動するマイクロプロセッサと、前記二つのアーキテクチャ用のアプリケーション・ソフトウェアを記憶する外部メモリ・デバイスと、前記マイクロプロセッサを前記外部メモリ・デバイスに接続するシステム・バスとを含み、

10 前記マイクロプロセッサが、前記システム・バスに接続された内部バスを有し、前記マイクロプロセッサが、前記第一のアーキテクチャの第一の命令セットの命令をデコードし、前記第二のアーキテクチャの第二の命令セットの命令を直接デコードし、第一の命令セットのデコードされた命令を前記第二の命令セットの一つ以上の命令に対してマッピングするための命令セット管理手段と、

前記第一および第二のアーキテクチャについて仮想アドレスから実アドレスへのアドレス変換を実行するためのメモリ管理手段と、

20 メモリから読み出されるプログラムのアーキテクチャ・コンテキストを、前記第一のアーキテクチャのコードまたは前記第二のアーキテクチャのコードのいずれかとして検出し、前記命令セット管理手段および前記メモリ管理手段を制御して、前記第一のアーキテクチャのアドレス変換と前記第二のアーキテクチャのアドレス変換との間で動的に切り換え、前記第二のアーキテクチャの、一つ以上のマッピングされてデコードされた命令または直接デコードされた命令を実行するための制御手段と、を含むことを特徴とするコンピュータ・システム。

【請求項14】前記マイクロプロセッサの前記メモリ管理手段が、実効アドレスを仮想アドレスに変換する際に第一または第二のアーキテクチャ変換方法のどちらがメモリ管理装置によって使用されるかを制御するためのモード制御機構を含む請求項13記載のコンピュータ・システム。

【請求項15】前記モード制御機構が前記プロセッサの命令取出しおよびデコード機構を制御して、前記第一および第二のアーキテクチャの命令が、前記命令セット管理手段による適切なデコードのために取り出され、配列されるようにする請求項14記載のコンピュータ・システム。

【請求項16】前記メモリ管理装置が、前記第二のアーキテクチャのページ・テーブル項目からページ・モード制御ビットを読み出し、前記ページ・モード制御ビットが前記制御手段に供給されて、前記メモリ管理手段によるアドレス変換を制御する請求項15記載のコンピュータ・システム。

【請求項17】前記制御手段が、プロセッサがどちらのアーキテクチャ・コンテキストの

下で作動するかを制御するためのアーキテクチャ・コンテキスト制御機構であって、実効アドレスを仮想アドレスに変換する際に前記マイクロプロセッサのメモリ管理装置によって使用されるアーキテクチャ変換方法を制御し、さらに、前記マイクロプロセッサの命令取出しおよびデコード論理を制御し、さらに、プロセスおよび構築されたリソースの実行コンテキストを制御し、さらに、前記マイクロプロセッサの割込みおよび例外機構を制御するためのアーキテクチャ・コンテキスト制御機構と、一つのアドレス変換機構が、一方のアーキテクチャのアドレスをもう一方のアーキテクチャのアドレス変換に対してマッピングすることを許容し、統合された割込みおよび例外機構が、割込みまたは例外が生じた際に実効中のアーキテクチャ・コンテキストにかかわりなく、非同期的な割込みおよびページ変換ならびに保護関連の例外を取り扱うことを許容する拡張および限定を前記二つのアーキテクチャに対して可能にするための修飾モード制御機構と、を含む請求項 1 3 記載のコンピュータ・システム。

【請求項 1 8】前記マイクロプロセッサの前記命令セット管理手段が、

前記第一の命令セットの命令をデコードするための第一のデコード手段と、

前記第二の命令セットの命令をデコードするための第二のデコード手段と、

前記第一のデコード手段からのデコードされた命令を前記第二の命令セットの一つ以上のデコードされた命令に対してマッピングするためのマッピング手段と、

前記マッピング手段からのデコードされた命令または前記第二のデコード手段からのデコードされた命令を選択するための、前記制御手段によって制御される選択手段と、を含む請求項 1 3 記載のコンピュータ・システム。

【請求項 1 9】前記第一および第二のデコード手段が前記第一および第二のアーキテクチャの簡単な命令をデコードし、簡単な命令が、基本的な演算クラスの中にマッピングし、一つの実行装置によって取り扱わることができる命令であり、前記命令管理手段がさらに、

前記第一の命令セットの複雑な命令をデコードするための第三のデコード手段と、

前記第二の命令セットの複雑な命令をデコードするための第四のデコード手段と、

前記第三または第四のデコード手段からのデコードされた命令を選択するための、前記制御手段によって制御される第二の選択手段と、

前記第三または第四のデコード手段からのデコードされた命令を前記第二の命令セットの多数の簡単な命令に対してマッピングするための、前記第二の選択手段の出力を受ける第二のマッピング手段と、

複雑な命令がデコードされる場合には前記第二のマッピング手段の出力を選択し、簡単な命令がデコードされる

場合には前記第一の選択手段の出力を選択するための、前記第三または第四のデコード手段の一方からの有効な信号に応答する第三の選択手段と、を含む請求項 1 8 記載のコンピュータ・システム。

【請求項 2 0】前記マイクロプロセッサの前記制御手段が、前記プロセッサ内のレジスタ中に記憶された、前記第二のアーキテクチャのアドレス変換を可能にするか不能にするかを決定する第一のビット、メモリ中の現在のページが前記第一のアーキテクチャのものか前記第二の

アーキテクチャのものかを示す第二のビットおよびアーキテクチャ修飾ビットである第三のビットを含む複数のビットの状態に依存して、前記プロセッサが複数の状態の一つに入るよう制御するモード制御装置を含む請求項 1 3 記載のコンピュータ・システム。

【請求項 2 1】前記プロセッサが、主メモリから読み出される命令のページ・モードを検出し、メモリ中の現在のページが前記第一のアーキテクチャのものか前記第二のアーキテクチャのものかを前記第二のビットによって前記モード制御装置に知らせるメモリ管理装置を含む請求項 2 0 記載のコンピュータ・システム。

【請求項 2 2】前記モード制御装置が、機能制御レジスタをさらに含み、前記プロセッサの起動またはリセット状態に応答して、前記プロセッサを前記第一および第二のアーキテクチャにそれぞれ対応する前記第一または第二のモードのいずれかで初期化し、その後、前記機能制御レジスタ中のビットの状態がアーキテクチャ・コンテキスト間での動的な切換えを可能にする請求項 2 0 記載のコンピュータ・システム。

【請求項 2 3】前記マイクロプロセッサが、サポートされる二つのアーキテクチャに共通のフォーマットを使用して具現化される一つのメモリ管理装置を有している請求項 1 3 記載のコンピュータ・システム。

【請求項 2 4】前記マイクロプロセッサが、前記サポートされる二つのアーキテクチャによって共用される一つの命令取出し機構と、別々の命令デコード機構とを有している請求項 1 3 記載のコンピュータ・システム。

【請求項 2 5】前記マイクロプロセッサのすべての実行リソースが前記サポートされる二つのアーキテクチャに共通である請求項 1 3 記載のコンピュータ・システム。

【請求項 2 6】別個の命令セットおよびメモリ管理方式を有する第一および第二のアーキテクチャをサポートするプロセッサにおいて、

前記第一および第二のアーキテクチャ用に書かれたアプリケーション・プログラムを記憶する外部メモリに接続するためのシステム・インターフェースと、

前記第二のアーキテクチャのページ・テーブル項目からページ・モード制御ビットを読み出すための、前記システム・インターフェースに接続されたメモリ管理装置と、第一の命令セットの命令をデコードし、デコードされた命令を第二の命令セットの一つ以上のデコードされた命

令に対してマッピングするための第一のデコード手段と、第二の命令セットの命令をデコードするための第二のデコード手段と、前記第一または第二のデコード手段によってデコードされた命令を選択するための選択手段とを含む取出しおよびデコード機構を含む命令装置と、第一および第二のアーキテクチャ・モードのどちらを可能にするかに依存してアクセスすることができる複数のレジスタを有する、前記命令装置からのデコードされた命令を受信し、実行するために接続された実行装置と、前記命令装置および前記実行装置に接続されたモード制御装置とを含み、前記メモリ管理装置によって読み出される前記ページ・モード制御ビットが前記モード制御装置に供給され、前記第一または第二のアーキテクチャ・モードのいずれかを可能にしてアドレス変換を制御し、前記プロセッサの前記命令取出しおよびデコード機構を制御して、前記第一および第二のアーキテクチャの命令が適切なデコードに備えて取り出され、配列されるようにすることを特徴とするプロセッサ。

【請求項 27】前記モード制御装置が、前記プロセッサ内のレジスタ中に記憶された、前記第二のアーキテクチャのアドレス変換を可能にするか不能にするかを決定する第一のビット、メモリ中の現在のページが前記第一のアーキテクチャのものか前記第二のアーキテクチャのものかを示す第二のビットおよびアーキテクチャ修飾ビットである第三のビットを含む複数のビットの状態に依存して、前記プロセッサが複数の状態の一つに入るよう制御する請求項 26 記載のプロセッサ。

【請求項 28】前記モード制御装置が、機能制御レジスタをさらに含み、前記プロセッサの起動またはリセット状態に応答して、前記プロセッサを前記第一および第二のアーキテクチャにそれぞれ対応する前記第一または第二のモードのいずれかで初期化し、その後、前記機能制御レジスタ中のビットの状態がアーキテクチャ・コンテキスト間での動的な切換えを可能にする請求項 27 記載のプロセッサ。

#### 【発明の詳細な説明】

##### 【0001】

【発明の属する技術分野】本発明は一般にマイクロプロセッサに関し、詳細には、二つの別個の命令セット・アーキテクチャ（以下、単に「アーキテクチャ」という）に対する拡張をサポートすることができるアーキテクチャ・モード制御を備えたマイクロプロセッサに関する。

##### 【0002】

【従来の技術】現在、パーソナル・コンピュータには、競合する二つのマイクロプロセッサ・アーキテクチャが用いられている。X86アーキテクチャと呼ばれる一方は、Intel社によって開発されたものであり、あるファミリーのマイクロプロセッサ、特に80386、80486、Pentium（登録商標）およびP6（商標）をサポートする。PowerPC（登録商標）と呼ばれるもう一方は、Internatio

nal Business Machines社とMotorola社によって共同開発されたものであり、現在、複数のPowerPCプロセッサを含む（PowerPCはIBM社の商標である）。PowerPCプロセッサは縮小命令セット・コンピュータ（RISC）プロセッサであり、一方、X86アーキテクチャは複合命令セット・コンピュータ（CISC）アーキテクチャの一例である。

【0003】X86アーキテクチャ用のソフトウェアの非常に大きなインストール済みのベースおよびPowerPCの

10 处理能力を利用するために新たに書き込まれたソフトウェアを含む広い範囲のソフトウェアをサポートする必要がある。二つのアーキテクチャを具現化するプロセッサは、そのような具現化を達成して、いずれのアーキテクチャからのソフトウェアの実行をも可能にし、よってその潜在的な市場を拡大する。そのようなプロセッサが多重タスク環境においていずれのソフトウェア標準をも動的に作動させることができるならば、その有用性および潜在的な市場性は大幅に高まる。しかし、二つのアーキテクチャをこの方法で作動させることに関してはいくつか問題がある。これらのアーキテクチャは、二つのアーキテクチャに固有の異なる命令セットおよび異なるアドレス空間の使用を含む。ある対処法は、RISCプロセッサ上でCISCアーキテクチャのソフトウェア・エミュレーションを実行するやり方である。しかし、この対処法は、RISCプロセッサの処理速度を犠牲にし、二つの異なるアーキテクチャ用に書かれた多重タスク処理ソフトウェアをサポートしない。求められるものは、RISCプロセッサ速度の潜在能力を最大に実現し、それでいて、二つのアーキテクチャ間の完全な互換性を保証するハードウェア的解決方法である。

【0004】RISCプロセッサ、例えばPowerPCは、非常に限られた命令セットを有するが、最新のCISCプロセッサは、簡約な命令および複雑な命令の両方を含む非常に広い命令セットを有している。CISCプロセッサの命令セットをRISCプロセッサに加えるならば、RISCプロセッサの設計の他ならぬ目的を頓挫させことになる。したがって、RISCプロセッサがその限られた命令セットを用いてCISC命令を実行することができるようCISC命令セットを変換することは、はなはだしく大きな問題である。この問題は、適切なデコードを達成することができるよう、二つの異なる命令セット用に書かれた命令どうしを区別する必要性によってさらに悪化する。二つの異なるアーキテクチャ用に書かれたプログラムの多重タスク処理を達成しなければならないならば、それら二つの異なる命令セット用に書かれた命令の適切な識別およびデコードを動的かつユーザに対して透過的に行わなければならない。

【0005】一つのプロセッサ上で二つのアーキテクチャをサポートし、いずれかのアーキテクチャ用に具現化されたソフトウェアの中で動的多重タスク処理を可能に

するには、そのプロセッサの実行装置が作動するところのアーキテクチャ・コンテキストに対して制御を加えることをまぬがれない。X86アーキテクチャとPowerPCのアーキテクチャとは、例えば、命令セットの設計においてだけでなく、各命令が実行リソース、例えばレジスタや結果フラグに対して配する仮説においても大きく異なる。これらのリソースはまた、プロセッサ中の相当な空き領域を占める。オペラントのサイズおよびタイプ、許容可能な演算ならびに演算の同期化要件もまた、アーキテクチャごとに異なる。

【0006】PowerPCアーキテクチャは、固定小数点演算に用いられる32個の汎用レジスタ (GPR) のセットと、浮動小数点演算に用いられる32個の浮動小数点レジスタ (FPR) の別個のセットとを定義する。それぞれの固定小数点演算または浮動小数点演算には32個のレジスタのいずれを使用してもよい。レジスタ中に保持される値は常に右寄せされる。特定の命令がレジスタとメモリとの間でデータをロードし、記憶するために定義され、別個の命令セットがレジスタ中のデータに対して演算を加えるために定義されている。例えば、データをメモリからロードしたり、それをレジスタ中の値に加えるための命令は定義されていない。演算を実行するために二つの別個の命令が要求されることになる。

【0007】X86アーキテクチャは、8個のGPRおよび8個のFPRからなるセットを定義する。FPRは、レジスタ・ファイルとしてではなく、スタックとして編成されている。特定の命令が、GPR中のレジスタを使用する方法に対して制限を加えて、GPRの汎用性を弱めている。例えば、ムーブ・ストリング (move string) 演算は、インデックス・レジスタとしてのEDIおよびESIの使用を制限する。GPRのうち4個においては、値を右寄せする必要はない。逆に、それらの値は、レジスタの第二のバイトから直接参照することができる。多くの命令が記憶場所に対して演算を実行することができる。例えば、加算命令は、一つのソースをGPRから取り出し、別のソースをメモリから取り出し、結果を元のソース記憶場所に書き込むことができる。

【0008】PowerPCの固定小数点および浮動小数点の実行命令はしばしば、三つのレジスタ・オペラント、すなわち二つのソース・オペラントおよび一つの目標を定義する。同様なX86命令は二つのオペラント、すなわちソース・オペラントおよびソース/目標オペラントだけを定義する。PowerPCプロセッサの命令に含まれるオペラントとは違い、X86オペラントの一方または両方が、レジスタだけではなく、記憶場所であることもできる。

【0009】これら二つのアーキテクチャの実行リソース仮説の間には、それらをさらに区別する違いが他にも数多くある。例えば、PowerPCアーキテクチャは、一つのレジスタ内に8個の結果制御フィールドを定義し、比較および分岐の命令が8個のフィールドのいずれに対し

ても演算を加えることができ、コード生成において最適化コンパイラに大きな融通性を与える。X86アーキテクチャは、比較および分岐（飛越し）命令によって使用される1セットの結果制御しか定義しない。

【0010】異なる命令セット・アーキテクチャに直接関連するさらなる問題は、命令そのものが主メモリから取り出され、プロセッサの取出しおよびデコード論理によってデコードされるところのアーキテクチャ・コンテキストに対する制御である。この場合もまた、X86アーキテクチャとPowerPCアーキテクチャとは、そのような論理に対して課す要件において大きく異なる。

【0011】PowerPCアーキテクチャは、演算コードおよびオペラント情報が固定位置にある状態で、すべての命令をちょうど4バイトの長さに定義する。命令は常に1語（4バイト）境界上に配列され、その結果、キャッシュ、ページまたはセグメントの境界を越えることは決してない。

【0012】他方、X86アーキテクチャは、オペラント情報が命令および演算コード前置に依存する不規則な位置にある状態で、可変長の命令を定義する。命令は、バイト境界にだけ配列され、したがって、キャッシュ、ページまたはセグメントの境界を越えることもある。その結果、アーキテクチャごとに命令取出しおよびデコード論理の設計に課される要求が大きく異なり、X86の要求がPowerPCの要求よりも効率的に具現化するのがはるかに困難である。

【0013】もう一つの問題は、基礎にあるオペレーティング・システムが二つのアーキテクチャのアドレス変換機構の一方しか管理することができないことによる、メモリ管理である。これには二つの有意な理由がある。

一つは、オペレーティング・システムの仮想メモリ管理部分 (VMMと呼ぶ) が二つのアーキテクチャの一方のためにしか書かれていないことである。もう一つは、既存のプロセッサが、プロセッサの命令セット・アーキテクチャを直接サポートしているメモリ管理装置 (MMU) を1個しか含まないことである。MMUは、プロセッサ・ダイ上の有意な物理的空間を占め、そのため、物理的空間の制約が、二つのアーキテクチャをサポートする一つのプロセッサの具現化に対してさらなる妨げを課す。

【0014】PowerPCおよびX86の両プロセッサ・アーキテクチャは、大きな仮想メモリ空間をより小さな物理アドレス空間の中にマッピングすることができるメモリ管理方式を定義する。いずれのアーキテクチャにおいても、仮想アドレスから物理アドレスへの変換は二段階処理である。まず、命令実行の一部として計算された実効アドレスがセグメント変換を受けて仮想アドレスを形成する。次に、この仮想アドレスがページング機構によって変換されて物理アドレスを形成する。これが基本的な処理であるが、言葉づかいが異なる場合もある。例え

ば、X86の文献は、実効アドレスを論理アドレスのオフセット部と呼び（セレクタが論理アドレスの残り部分を形成する）、仮想アドレスを線形（リニア）アドレスと呼ぶことがある。基本的なアドレス変換処理における類似性にもかかわらず、二つのアーキテクチャの間でセグメントおよびページ変換の詳細は大きく異なる。

【0015】PowerPCアーキテクチャの64ビット版においては、ハッシュ合計されたセグメント・テーブル探索によって実効アドレス（EA）が仮想アドレス（VA）に変換される。EAから抽出された実効セグメント識別（ESID）の下寄り5ビットがハッシュ合計され、次いでアドレス空間レジスタと連結されて、メモリ中のセグメント・テーブル・グループの実アドレスを形成する。実効セグメントIDが元のEAのそれに一致する項目が見つかるまで個々のセグメント・テーブル・グループ項目が探索される。見つかると、仮想セグメントID（VID）がセグメント・テーブル・グループ項目から抽出され、元のEAのページおよびバイト・フィールドと連結されてVAを形成する。

【0016】PowerPCアーキテクチャの32ビット版においては、EAの上寄り4ビットが16個のセグメント・レジスタの1個への指標として使用される。VIDがセグメント・レジスタから抽出され、元のEAのページおよびバイト・フィールドと連結されてVAを形成する。

【0017】X86アーキテクチャ・アドレス変換においては、直接セグメント・テーブル・ルックアップによってEAがVAに変換される。6個のレジスタ1個から取り出されたセレクタ値が二つの記述子テーブルの一方へのポインタとして使用される。セレクタによって指された記述子テーブル項目は基底アドレスを含み、この基底アドレスが元のEAに加えられてVAを形成する。X86の参照資料は通常、EAを「オフセット」と呼び、セレクタとEAとの組合せを「論理アドレス」と呼び、VAを「線形アドレス」と呼んでいる。

【0018】ページ変換もまた、二つのアーキテクチャにおいて異なる。PowerPCアーキテクチャにおいては、ハッシュ合計されたページ・テーブル探索によってVAが物理アドレス（PA）に変換される。仮想セグメントIDの下寄り39ビットとVAからのページ・フィールドとがハッシュ合計され、次いで、ページ・テーブルの元のレジスタとマスク／併合されて、メモリ中のページ・テーブル・グループの実アドレスを形成する。仮想セグメントIDが元のVAのそれに一致する項目が見つかるまで個々のページ・テーブル・グループ項目が探索される。見つかると、実ページ番号がページ・テーブル・グループ項目から抽出され、元のVAのバイト・フィールドと連結されて64ビットPAを形成する。

【0019】X86アーキテクチャにおいては、直接的な2レベルのページ・テーブル・ルックアップによってVAがPAに変換される。VAの高位10ビットが、基底が

ページ・ディレクトリ・レジスタによって決定されるページ・ディレクトリ・テーブルへのポインタとして使用される。VAによって参照されるページ・ディレクトリ・テーブルの中の項目は、ページ・テーブルの基底アドレスを含む。VAの中間10ビットがこのページ・テーブルへのポインタとして使用される。このポインタによって参照されるページ・テーブル項目は、変換される仮想ページに対応する、メモリ中の物理ページの実ページ番号を含む。実ページ番号がVAのオフセット・フィールドと組み合わされて、最終的なPAを形成する。

【0020】最後に、デュアルアーキテクチャ多重タスク処理プロセッサは、外部的および非同期的な割込みならびに同期的な例外、すなわち障害が受け入れられるところのコンテキストを管理することができなければならない。X86アーキテクチャとPowerPCアーキテクチャとは、割込みおよび例外に対して二つの異なる方式を定義している。

【0021】PowerPCアーキテクチャは、外部的割込みの結果として制御が移される一つの場所を定義する。システムに問い合わせることによって割込みのベクトル番号が何であるかを決定する負担はソフトウェアに課される。すべての割込みおよび障害は、二つの可能な記憶場所の一方において、実アドレス・モードで受け入れられる。戻りアドレスは、割込み戻り命令による使用に備えてレジスタ中に記憶される。

【0022】PowerPCに関するさらに詳細な情報については、Morgan Kaufman Publishing社（カリフォルニア州サンフランシスコ）出版の「PowerPC Architecture Specification for a New Family of RISC Processor」、IBM Corporation ICN 1-55860-C16-6（IBM社、1993、1994）を参照されたい。

【0023】

【発明が解決しようとする課題】したがって、本発明の目的は、一つの多重タスク処理オペレーティング・システムの下で二つの別個のアーキテクチャをサポートするプロセッサを提供することにある。

【0024】本発明のもう一つの目的は、二つの別個のアーキテクチャそれぞれに対する拡張および／または限定（制限）を可能にし、プロセッサが作動するところのアーキテクチャ・コンテキストを制御する一つのマイクロプロセッサを提供することにある。

【0025】本発明のもう一つの目的は、サポートされる二つのアーキテクチャのための命令セット定義を修飾することができ、それぞれのアーキテクチャにおいて定義されたリソースを他方のアーキテクチャ用に書かれたソフトウェアによってアクセスすることができるようになるマイクロプロセッサを提供することにある。

【0026】本発明のさらなる目的は、実行リソースが作動するところのアーキテクチャ・コンテキストを決定して、実行コンテキストを一方のアーキテクチャからも

う一方のアーキテクチャに動的に切り換えることができるようとするマイクロプロセッサを提供することにある。

【0027】本発明のさらに別の目的は、二つの別個のアーキテクチャをサポートし、ソフトウェアが種々の機構にアクセスして、マイクロプロセッサを、修飾モード制御を可能／不能にし、アーキテクチャ・コンテキスト制御機構に影響することができる既知の状態で初期化するモード制御装置を有するマイクロプロセッサを提供することにある。

【0028】本発明のさらにもう一つの目的は、二つの別個のアーキテクチャをサポートし、両方のアーキテクチャについて仮想アドレスから実アドレスへのアドレス変換を実行することができるメモリ管理ハードウェアを有し、アドレス変換を生じさせて、変換機構を一方のアーキテクチャからもう一方のアーキテクチャに切り換えることができるよう設計されたマイクロプロセッサを提供することにある。

【0029】本発明のさらに別の目的は、二つの別個のアーキテクチャをサポートし、両方のアーキテクチャについてメモリ保護検査を実行することができるメモリ保護検査ハードウェアを有し、一方のアーキテクチャのメモリ・リソースを他方のアーキテクチャのメモリ・リソースから保護することができるような方法でメモリ保護検査を生じさせるマイクロプロセッサを提供することにある。

【0030】本発明のさらなる目的は、二つの別個のアーキテクチャをサポートし、割込みおよび例外が受け入れられるところのアーキテクチャ・コンテキストを決定して、割込みコンテキストを一方のアーキテクチャからもう一方のアーキテクチャに切り換えることができるようとするマイクロプロセッサを提供することにある。

### 【0031】

【課題を解決するための手段】本発明によると、一つの多重タスク処理オペレーティング・システムの下で作動し、別個の命令セットおよびメモリ管理方式を有する第一および第二のアーキテクチャをサポートするマイクロプロセッサが提供される。このマイクロプロセッサは、第一のアーキテクチャの第一の命令セットの命令をデコードし、第二のアーキテクチャの第二の命令セットの命令をデコードする命令セット管理手段を含む。命令セット管理手段は、第一の命令セットのデコードされた命令を第二の命令セットの一つ以上の命令に対してマッピングする。マイクロプロセッサはさらに、前記第一および第二のアーキテクチャについて仮想アドレスから実アドレスへのアドレス変換を実行するメモリ管理手段を含む。制御手段が、メモリから読み出されるプログラムのアーキテクチャ・コンテキストを、前記第一のアーキテクチャのコードまたは前記第二のアーキテクチャのコードのいずれかとして検出し、検出されたアーキテクチャ

・コンテキストに依存して、命令セット管理手段および前記メモリ管理手段を制御して、第一のアーキテクチャのアドレス変換と第二のアーキテクチャのアドレス変換との間で動的に切り換えて、第二のアーキテクチャの、一つ以上のマッピングされてデコードされた命令または直接デコードされた命令を実行する。

【0032】本発明の具体的な実施態様においては、マイクロプロセッサには、二つのアーキテクチャに対する拡張および限定を可能にするアーキテクチャ・モード制御装置が設けられている。このような拡張および限定は以下を可能にする。

【0033】・一方のアーキテクチャにおける既存の命令に対する新たな命令および拡張を可能にして、他方のアーキテクチャ独自のリソースへのアクセスを許容する。

【0034】・一方のアーキテクチャが他方のアーキテクチャのリソースを十分に見ることができること。

【0035】・一つのアドレス変換機構が一方のアーキテクチャのアドレスの変換をもう一方のアーキテクチャの変換に対してマッピングすることができる効力をもつ。

【0036】・一方のアーキテクチャの保護機構を他方のアーキテクチャのそれに対してマッピングする。

【0037】・統合された割込みおよび例外機構が、割込みまたは例外が生じた際に実効中のアーキテクチャ・コンテキストにかかわりなく、非同期的割込みおよびページ変換ならびに保護関連の例外を一つの機構によって取り扱うことを許容する。

【0038】加えて、アーキテクチャ・モード制御装置が、プロセッサの以下の分野を制御することにより、そのプロセッサが作動するところのアーキテクチャ・コンテキストを制御する（コンテキスト制御）。

【0039】・二つのアーキテクチャ・モードによって共用される一つの命令取出し機構と、所与のコンテキスト制御にとって適当である場合にのみ活動するアーキテクチャごとに別々の命令デコード機構とがある。しかし、そのようなコンテキスト制御は、多数の命令取出し機構および／または一つの多重アーキテクチャ・デコーダを用いる具現化において使用することができる。

【0040】・すべての実行リソースが二つのアーキテクチャ・モードの間で共通である。しかし、そのようなコンテキスト制御は、共用または共通のリソースを用いない具現化において使用することができる。例えば、ある具現化は、X86アーキテクチャとPowerPCアーキテクチャとで別々のレジスタ・ファイルを有することができる。コンテキスト制御は、オペランドおよび結果アクセスに適当なレジスタ・ファイルを選択するために使用されるであろう。

【0041】・サポートされる二つのアーキテクチャに共通のフォーマットを使用して、一つのメモリ管理装置

(MMU) が具現化される。しかし、そのようなコンテキスト制御は、多数のMMUを用いる具現化において使用されて、コンテキスト制御によって与えられるアーキテクチャに適当なMMUによって変換を駆動することができる。スーパバイザレベルのコードをユーザレベルのコードから保護する場合にページ保護機構がプロセッサMMUによって使用される。

## 【0042】

【発明の実施の形態】一例として、IBMのPowerPCファミリーのプロセッサであるRISCプロセッサを、IntelのX86ファミリーのプロセッサであるCISCプロセッサのメモリ管理方式および命令セットをサポートするように変更する具体的な実施態様によって本発明を説明する。ただし、本発明は、他の異なるプロセッサにも応用しうることが理解されよう。そのうえ、本発明の教示は、それぞれが異なるメモリ管理方式および命令セットを有する二つのRISCプロセッサ・アーキテクチャどうしの組合せまたは二つのCISCプロセッサ・アーキテクチャどうしの組合せに応用してもよい。また、当業者であれば、本発明を、多数のプロセッサ・アーキテクチャをサポートするように拡張しうることが認められよう。

【0043】ここで、図面、特に図1を参照すると、本発明を具現化しうるところの基本的なマイクロプロセッサ、例えばPowerPCマイクロプロセッサのブロック図が示されている。以下の論述は、マイクロプロセッサの基本的な動作を説明する。

【0044】マイクロプロセッサ10は、そのシステム・インターフェース101を介して、64ビット・データ・バス121および32ビット・アドレス・バス122を含むシステム・バス12に接続されている。システム・バス12は、多様な入出力(I/O)アダプタおよびシステム・メモリ(図示せず)に接続されている。マイクロプロセッサ10は、とりわけ、システム・メモリに対して読み書きを実行するためにシステム・バス12を使用する。アドレスおよびデータ・バスのマスタシップのアービトレーションは、中央の外部アービタ(図示せず)によって実行される。

【0045】システム・インターフェース101は、2要素読出し待ち行列1021および3要素書き込み待ち行列1022からなるメモリ装置102に接続されている。読出し待ち行列1021は、読出し動作のためのアドレスを含み、書き込み待ち行列1022は、書き込み動作のためのアドレスおよびデータを含む。このメモリ装置102は、一方で、メモリ管理装置(MMU)103に接続され、そこからアドレスを受ける。メモリ装置102はまた、命令およびデータの両方を記憶するキャッシュ104に接続されている。キャッシュ104中の命令およびデータ(オペランド)は、命令待ち行列1051と、プログラム・カウンタ1052と、送出し論理1053と、分岐履歴テーブル(BHT)を有する分岐

予測装置(BPU)とからなる命令装置105によってアクセスされる。

【0046】送出し論理1053は、命令のタイプを決定し、それを、ここでは整数装置(IU)106および浮動小数点装置(FPU)107によって表す複数の実行装置の対応する一つにディスパッチする。IU106は、スカラ(すなわち整数)演算を実行し、結果を汎用レジスタ(GPS)ファイル1062に記憶する算術論理演算装置(ALU)1061を含む。同様に、FPU107は、浮動小数点演算を実行し、結果を浮動小数点レジスタ(FPR)ファイル1072に記憶するALU1071を含む。GPRファイル1062およびFPRファイル1072それぞれからのデータ出力は、キャッシュ104に書き込まれ、そこからデータが、システム・メモリへの書き込みのためにメモリ装置102に移される。データの計算に加えて、IU106はまた、命令装置105によるアクセスのためのアドレスを計算し、一時的にこれらのアドレスをレジスタ1063中に記憶する。レジスタ1063中のアドレスが、BPU1054によって出力されるアドレスとともに、MMU103に供給される。

【0047】命令装置105はまた、割込み(プロセッサに対して外部にあるハードウェアによって開始される非同期的事象)ならびに例外および障害(命令を取り出したり、デコードしたり、実行したりする結果として生じる同期的事象)を処理する。割込みは、システム・インターフェース101を介してマイクロプロセッサ10に送られ、送出し論理1053に転送される。例外および障害(以下、単に「例外」と呼ぶ)は、命令待ち行列1051、メモリ管理装置103、IU106またはFPU107のいずれによっても検出し、送出し論理1053に転送することができる。送出し論理1053は、各例外の優先順位を定め、それらを、命令境界上の分岐予測装置1054に送る。そして、分岐予測装置1054が、命令装置105が命令を取り出す場所を適当な割込み/例外ハンドラの場所に変更する。

【0048】命令およびオペランドは、システムメモリからキャッシュ104を介して自動的に取り出されて命令装置105に入れられ、そこで、1クロックあたり命令3個の最大速度で実行装置にディスパッチされる。ロードおよび記憶の命令は、整数および浮動小数点レジスタ・ファイルとメモリ・システムとの間を行き来するオペランドの動きを指定する。命令またはデータアクセスが行われるとき、命令装置105(命令アクセスの場合)または整数装置106(データアクセスの場合)によって論理アドレス(実効アドレス)が計算される。メモリ管理装置103が実効アドレスを物理アドレスに変換し、それをキャッシュ104に転送する。メモリ管理装置103はまた、実効アドレスを物理アドレスに変換する際、マイクロプロセッサ10の現在の特権を検査して、メモリにアクセスしてもよいことを検証する。物理アドレス・ビットの一部がキャッシュ・タグ・ビットIN104と比較されて、

キャッシュ・ヒットが生じたかどうかを判定する。キャッシュ104においてアクセスを逸するならば、物理アドレスを使用してシステム・メモリにアクセスする。

【0049】マイクロプロセッサ10は、ロード、記憶および命令取出しに加えて、テーブル探索のための他の読み書き演算、キャッシュ・ミスののち、もっとも以前に使用された(LRU)セクタがメモリに書き込まれる場合のキャッシュ・キャストアウト演算および変更されたセクタが別のバス・マスタからのスヌープ・ヒットを経験する場合のキャッシュセクタ・スヌープ・プッシュアウト演算を実行する。すべての読み書き演算はメモリ装置102によって取り扱われる。干渉性を維持するため、書き込み待ち行列1022がスヌーピングに含まれる。メモリは、デバイスがバス・マスタシップと求めて競合することを許すアービトレーション機構を介してアクセスされる。

【0050】マイクロプロセッサ10はまた、種々の装置が作動するところのアーキテクチャ・コンテキストならびに所与のアーキテクチャ・コンテキストの下でそれらの装置に加えられるかもしれないアーキテクチャ修飾または拡張を制御するモード制御装置108を含む。メモリ管理装置(MMU)103が、どのアーキテクチャに命令が適合するのかを検出する。例えば、MMU103は、命令がX86命令であるのか、PowerPC命令であるのかを判断し、ページ・モード制御(P)ビットにより、相応なアーキテクチャ・コンテキストをモード制御装置108に知らせてよい。モード制御装置108はまた、PowerPC機械状態レジスタ命令再配置(MSR IR)ビット109から仮想(V)ビットを受ける。モード制御装置108は、修飾(Q)ビットを生成し、保持する。このQビットが命令装置105に出力され、命令装置105が命令を取り出し、デコードする方法を決定する。Qビットはまた、整数装置(IU)106および浮動小数点装置(FPU)107に出力され、どのレジスタ・リソースが整数装置106および浮動小数点装置107に利用できるかを決定する。モード制御装置108からのQビットはまた、割込み／例外が生じた際に分岐予測装置1054が命令装置105に指示し直す方法を統制する。モード制御装置はまた、PおよびVビットならびにモード制御装置108によって内部的に生成されるQビットに基づき、現在一方のアーキテクチャで作動中のプログラム中の点を他方のアーキテクチャで作動させるための異なるプログラムへのモード切換えが行われたときに制御するモード切換え信号を生成する。

【0051】アーキテクチャへの拡張は、新たな命令およびレジスタを含むかもしれない。限定は、特定のレジスタへのアクセスを不能にすること、すなわち、アドレスを変換する方法に対する制限を含むかもしれない。拡張および／または限定の背後にある第一の目的は、それぞれのアーキテクチャで書かれたソフトウェアが、他方

のアーキテクチャによって定義されたリソースに対してもある程度のアクセスを有することを許すことである。第二の目的は、アーキテクチャ・コンテキストが変わると、それぞれのアーキテクチャで書かれたソフトウェアが、他方のアーキテクチャで書かれたソフトウェアに制御を移すことを許すことである。実際には、アーキテクチャ・モード制御装置108によって可能になる拡張は、ソフトウェアがアーキテクチャ・コンテキストにおける変更を呼び出すことを許す機構を含む。

【0052】プロセッサのアーキテクチャ・コンテキストは、単に、そのプロセッサが作動するところの現在の命令セット・アーキテクチャ・コンテキストである。例えばPowerPCおよびX86の両アーキテクチャをサポートするプロセッサにおいては、コンテキスト制御が、プロセッサがPowerPCプロセッサのように挙動するのかX86プロセッサのように挙動するのかを決定する。アーキテクチャ修飾制御(拡張／限定を可能にする)およびアーキテクチャ・コンテキスト制御(コンテキストを決定する)はいずれも以下のそれぞれに直接的な影響を及ぼすことができる。

#### 【0053】・命令セット定義機構

- ・命令コード化機構
- ・命令演算コード長さ機構
- ・アドレス変換機構
- ・セグメントおよびページ・テーブル編成機構
- ・保護機構
- ・割込みアーキテクチャ機構
- ・メモリ・アドレス指定性機構
- ・レジスタ・セットおよびレジスタ機構
- ・条件、フィールドおよび結果機構

【0054】本発明の好ましい実施態様においては、モード制御装置108は、一方のアーキテクチャのアドレス変換を他方のそれに対してマッピングすることができる一つのMMU103によって制御される。モード制御装置108はさらに、メモリ保護検査ハードウェアを制御して、両方のアーキテクチャ用に書かれたソフトウェアを一つのオペレーティング・システムの制御の下で保護し、多重タスク処理することができるようになる。

【0055】図2は、PowerPCアーキテクチャのうち、40 実効アドレスから仮想アドレスへの変換(セグメント化)を実行する部分のブロック図である。64ビットの実効アドレスがレジスタ21中に保持され、一方で、アドレス空間レジスタ(ASR)22がセグメント・テーブルの実アドレスを保持する。EAレジスタ11から抽出された実効セグメント識別(ESID)の下寄り5ビット、すなわちビット31～35がハッシュ機能23によってハッシュ合計され、次いでASR22のビット0～51と連結されて、セグメント・テーブル項目レジスタ24中に実アドレスを形成する。この実アドレスの最後のバイトは0に強要される。セグメント・テーブル項目レジスタ24は、40

96バイトを含むメモリ中にセグメント・テーブル25をアドレス指定する。ハッシュ合計されたセグメント・テーブル探索によって実効アドレス（EA）が仮想アドレス（VA）に変換される。実効セグメントIDが元のEAのそれに一致する項目が見つかるまで個々のセグメント・テーブル・グループ項目が探索される。見つかると、セグメント・テーブル・グループ項目26から仮想セグメントIDが抽出され、元のEAのページおよびバイト・フィールドと連結されて、80ビットVAをレジスタ27中に形成する。

【0056】図3に示すX86アーキテクチャ・アドレス変換においては、直接的なセグメント・テーブル・ルックアップによってEAがVAに変換される。6個のレジスタ31の1個から取り出されたセレクタ値が二つの記述子テーブル32の一方へのポインタとして使用される。セレクタによって指された記述子テーブル項目は、記述子テーブル基底レジスタ33から読み出され、加算器35によってEAレジスタ34中の元のEAに加えられてVAをVAレジスタ36中に形成する基底アドレスを含む。X86の参照資料は通常、EAを「オフセット」と呼び、セレクタとEAとの組合せを「論理アドレス」と呼び、VAを「線形アドレス」と呼んでいる。

【0057】ページ変換もまた、二つのアーキテクチャ間で異なる。図4に示すPowerPCアーキテクチャにおいては、ハッシュ合計されたページ・テーブル探索によってレジスタ27中のVAが物理アドレス（PA）に変換される。具体的には、レジスタ27中の80ビット仮想アドレスのビット52～67（ページ・フィールド）がレジスタ42中の23個の0と連結される。そして、レジスタ27中の仮想セグメントIDのビット13～51とレジスタ42の内容とがハッシュ機能43においてハッシュ合計されて、レジスタ44中に39個のビットを生成する。ハッシュ・テーブル・レジスタ45中のビット58～63がデコーダ46によってデコードされて、レジスタ47中に28ビットのマスクを生成する。レジスタ44のビット0～27が、ANDゲート48の中でレジスタ中のマスクによってマスクされ、マスクされた出力がORゲート49の中でレジスタ45のビット18～45と合わされて、ページ・テーブル起点レジスタ50の中の28ビットを形成する。レジスタ50の最初の18ビットがレジスタ45のビット0～17から直接読み出され、次に高い11ビットがレジスタ44のビット28～38から読み出される。レジスタ50のもっとも高い7ビットが0に強要されて、ページ・テーブル51のメモリ中の実アドレスを形成する。仮想セグメントIDが元のVAのそれに一致する項目52が見つかるまで個々のページ・テーブル・グループ項目が探索される。見つかると、ページ・テーブル・グループ項目52から実ページ番号が抽出され、VAレジスタ27の元のVAのバイト・フィールド、すなわちビット68～79と連結されて、物理アドレス・レジスタ53中に64ビットのPAを形成する。

【0058】図5に示すX86アーキテクチャにおいては、直接的な2レベル・ページ・テーブル・ルックアップによってVAがPAに変換される。より詳細には、VAレジスタ36中のVAの高位10ビットが、基底がページ・ディレクトリ・レジスタ55によって決定されるページ・ディレクトリ・テーブル54へのポインタとして使用される。VAによって参照されるページ・ディレクトリ・テーブル54中の項目は、ページ・テーブル56の基底アドレスを含む。レジスタ36中のVAの中間10ビットがこのページ・テーブル56へのポインタとして使用される。このポインタによって参照されたページ・テーブル項目は、変換される仮想ページに対応するメモリ中の物理ページの実ページ番号を含む。この実ページ番号が加算器57によってレジスタ36中のVAのオフセット・フィールドと合わされて、物理アドレス・レジスタ58中の最終的なPAを形成する。

【0059】一つのプロセッサ上で作動することができる二つのアーキテクチャの具現化を達成するためには、図1に示すモード制御装置108によって制御しなければならない必須要素がいくつかある。具体的には、モード制御装置108は、以下の点で異なる二つのアーキテクチャを有する場合を取り扱う。

【0060】・命令セット定義、コード化および演算コード長

- ・アドレス変換
- ・セグメントおよびページ・テーブル編成
- ・保護機構
- ・割込みアーキテクチャ
- ・メモリアドレス指定性
- ・レジスタ・セット
- ・条件、フィールドおよび結果機構

【0061】アーキテクチャどうしが異なるすべての区域において、プロセッサの具現化は、各アーキテクチャの異なる側面を個々にサポートするハードウェアを含んでもよいし、すべてのアーキテクチャをサポートすることができる共通のハードウェアリソースを含んで、ハードウェアリソースの冗長性を除いてもよい。別個のハードウェア要素を使用してアーキテクチャをサポートする状況においては、アーキテクチャ・モード制御装置108

40 が、適当なハードウェア要素を可能にし、他の要素を不能にする責任を負う。例えば、プロセッサが、サポートされるアーキテクチャのそれぞれについて別々の命令セット・デコーダを具現化するならば、アーキテクチャ・モード制御装置は、現在使用中のアーキテクチャのための命令セット・デコーダを可能にし、残りのアーキテクチャのためのデコーダを不能にする。共通のハードウェアリソースを用いて冗長性を除く状況においては、アーキテクチャ・モード制御装置は、そのようなハードウェアに対し、適当ならば、現在のアーキテクチャ・コンテキストの規則の下で、そのコンテキストのために定義さ

れた拡張を利用しながら作動するよう指示する。例えば、プロセッサが、物理的ハードウェアおよび配線を最小限にするために共通のレジスタ・ファイルを具現化するならば、アーキテクチャ・モード制御装置は、所与のハードウェア・コンテキストの下で共通レジスタ・ファイル中のどのレジスタにアクセスしてもよいかを制御する。

【0062】したがって、本発明によると、モード制御装置108は、一つのアーキテクチャの異なる側面を個々にサポートするハードウェア・リソースの間で選択を行う。制御装置108はまた、多数のアーキテクチャの異なる要素をサポートすることができるような共通のハードウェア・リソースをも制御する。そのようなハードウェア・リソースは、冗長ハードウェアを除いて、それにより、物理的空間、電力消費を節約し、プロセッサ性能を改善し、全体の設計を簡素化するために具現化される。

【0063】アーキテクチャ修飾制御機構は、モード制御装置108中のプロセッサ機能制御レジスタ（図6に示す）中に保持されるビットの値によって決定される。このビットは、いずれかのアーキテクチャで作動中のソフトウェアによって設定することができる。このビットが0であるとき、アーキテクチャ、例えばPowerPCアーキテクチャまたはX86アーキテクチャのいずれにも修飾が加えられない。すなわち、これが正常な作動状態である。しかし、このビットが1であるとき、アーキテクチャ・コンテキスト制御機構の制御の下で現在作動中のアーキテクチャを修飾する。より詳細には、このビットが1であるとき、マイクロプロセッサは、マイクロプロセッサが、現在のアーキテクチャによって定義されない、他方のアーキテクチャ中のレジスタに対して読み書きすることを許す、利用できる新たな命令を現在のアーキテクチャ中に有する。

【0064】一例として、X86アーキテクチャは、PowerPCアーキテクチャには存在しない、FLAGSと呼ばれる状態／制御レジスタを有している。そのため、マイクロプロセッサがFLAGSレジスタに対して読み書きすることを許す新たなPowerPC命令が定義され、修飾制御ビットが1である場合にのみ、この命令を使用することができる。同様に、このビットは、現在のアーキテクチャ中のいくつかの命令を不能にする。一例として、修飾制御信号が1である場合、PowerPCアーキテクチャは、アーキテクチャ・コンテキストがX86モードであるとき、X86アーキテクチャのINVLPG（TLB中のページ・テーブル項目を無効化）命令をもはや認識しない。修飾制御機構が1であり、コンテキスト制御機構が0であるとき（PowerPCアーキテクチャ・モード）、X86アーキテクチャ型リソースへのアクセスをPowerPCアーキテクチャに与える、PowerPCアーキテクチャに対する拡張が可能になる。

【0065】例えば、PowerPCアーキテクチャの命令取

出し機構に対して、PowerPCプロセッサ用に設計されたソフトウェアがバイト整列されたX86ソフトウェアへと分岐することを許す機能強化が成される。PowerPCプロセッサ用に設計されたソフトウェアが64ビットX86記述子レジスタに対して読み書きすることを許すさらなるPowerPC命令が可能になる。最後に、オペレーティング・システムが、PowerPCプロセッサ用に設計されたコードを含む記憶場所を、X86コードを含む記憶場所から区別することを許す、PowerPCプロセッサ・ページング機構に対する拡張が可能になる。

【0066】図6は、例示的なモード制御装置108の関連の論理を示す論理図である。ハードウェア機能制御レジスタ61は、上記に説明したように、ソフトウェアによってセットされるラッチである。ラッチがセットされると、ラッチはANDゲート62を可能にし、このゲートがモード切換え信号を出力する。モード切換え信号は、処理されている現在のコードが完了したところでアーキテクチャ・コンテキスト切換えを可能にする信号である。モード切換え信号は、Vビット、PビットおよびQビットの状態に依存して生成される。V（仮想モード）ビットは、PowerPC機械状態レジスタ命令再配置（MSR\_I\_R）ビット109（図1を参照）によってモード制御装置108に入力され、PowerPC命令アドレス変換が可能にされた状態（V=1）か、不能にされた状態（V=0）かを示す。P（ページ・モード制御）ビットは、MMU103によって供給され、現在のページがPowerPCページである（P=0）のか、X86ページである（P=1）のかを示す。Qビットはアーキテクチャ修飾ビットである。このビットは、図1に示すように、命令装置105、整数装置（IU）106および浮動小数点装置（FPU）107に供給される。PビットおよびVビットがANDゲート63に入力され、このゲートの出力が排他的OR（XOR）ゲート64の一方の入力に供給される。XORゲート64の第二の入力は、Qビットを記憶するレジスタ66に接続されたインバータ65によって供給を受ける。レジスタ66の出力は、マルチプレクサ（MUX）67の一方の入力に直接供給され、また、インバータ68を介して、MUX67の他方の入力にも供給される。MUX67は、図9を参照しながらさらに詳細に示し、説明するように、分岐予測装置（BPU）1054（図1）からの遅延モード切換え信号（記号「」によって示す）によって制御される。

【0067】初期値（すなわちハードウェア・リセット時の値）は、V=0、P=X、Q=0およびレジスタ61=0である。このとき、Xは「don't care（不問）」を意味する。モード切換え信号は、レジスタ61を1に設定することによって可能になる。Qビットが0であり、ハードウェア機能制御レジスタ61が同様に1（X86アーキテクチャ・モード）に設定されると、X86アドレス変換機構に特定の限定が加えられる。具体的には、X86ページング機能が不能になり、それに代えて、セグメントお

よりページ変換の完全なPowerPCアドレス変換機構が配される。X86セグメント変換機構はなおも利用される。

【0068】特定の他のページング関連の動作もまた不能になる。具体的には、ページ・ディレクトリ基底レジスタに対するX86書き込みは効果を有さず、X86ページ変換モードを可能にすることはできず、X86ソフトウェアは、図1のMMU103によって内部的に保持された項目を無効化することができない。代わりに、これらの動作はプロセッサによって内部的に捕らえられ、適切なものとして取り扱われる。X86アーキテクチャに対する拡張もまた、アーキテクチャ修飾機構状態ビットによって可能になる。具体的には、X86命令は、特定のPowerPCアーキテクチャ型レジスタにアクセスすることができる。

【0069】マイクロプロセッサにおけるアーキテクチャ・コンテキスト制御は、モード制御装置108によって生成され、レジスタ66中に保持されるQビットの値によって決定される。例えば、このビットが0であるとき、マイクロプロセッサは、実行のための命令取出しおよびデコードから割込みおよび例外の取扱いのためのアドレス変換まで、PowerPCアーキテクチャに関連する完全な規則のセットに従う。このビットが1であるとき、プロセッサは完全なX86アーキテクチャ規則に従う。好ましい実施態様においては、リセット後のこのビットの初期値は0であり、プロセッサを、完全なX86アーキテクチャに従うところのモードに入れられる。

【0070】Qビットの値をアーキテクチャ・モード制御装置108によって変更して、マイクロプロセッサを、X86モードで作動させながらもPowerPCモードに入れたり、PowerPCモードで作動させながらもX86モードに入れたりすることができる。これはMUX67によって達成される。図7は、好ましい実施態様のモード制御装置108がアーキテクチャ・コンテキスト制御信号の値を変更する方法を示す状態図である。図7は、四つの状態、すなわち、完全なX86アーキテクチャ・モード、修飾X86アーキテクチャ・モード、修飾PowerPCアーキテクチャ・モードおよび完全なPowerPCアーキテクチャ・モードを示す。好ましい実施態様においては、モード制御装置108は、V、PおよびQビットの値を使用して、プロセッサを一つのアーキテクチャから別のアーキテクチャに進める。上述したように、Qビットはレジスタ66中に保持されており、二つのアーキテクチャのいずれかで作動中のソフトウェアによって設定することができる。ビットVもまた、ソフトウェア制御の下にあり、例外時にクリアされる。ビットPはMMU103によってモード制御装置108に供給される。

【0071】好ましい実施態様においては、アーキテクチャ・コンテキストのいずれかからのマイクロプロセッサのリセットがプロセッサを完全なX86モードに入れる。すなわち、マイクロプロセッサがリセットされるな

らば、コンテキストおよび修飾制御機構が何らかの既知の初期状態に置かれる。好ましい実施態様においては、リセットはプロセッサを修飾なしでX86コンテキストに残す。Q(図7を参照)が1にセットされない限り、プロセッサが完全なX86モードを出ることはない。しかし、V、PおよびQがすべての1にセットされるならば、マイクロプロセッサは修飾X86モードに入り、V、PおよびQが1であり続ける限り、そのモードにとどまる。修飾PowerPCモードには、完全なX86モードまたは修飾X86モードのいずれかから、二つの方法のいずれかを用いて、すなわち、Qが1であるときにVを0にセットすることにより、または、Pを0にセットしながらVおよびQを1にセットすることにより、入ることができる。完全なPowerPCモードには、Qが0にセットされるならば、両方の修飾モードのいずれからでも入ることができる。

【0072】図8は、送出し論理1053(図1)のデータの流れを示して、マイクロプロセッサの命令セット管理動作を説明する高レベル機能ブロック図である。これ

は、以下さらに詳述する図9にさらに詳細に示すハードウェアのデータの流れである。起動またはリセット時に、マイクロプロセッサは、省略時モードをとることによって始まる初期化モードに入る。好ましい実施態様においては、省略時モードは、図7に示すような、モード制御装置108に配線接続された完全なX86モードである。MMU103は初めクリア状態である。起動またはリセット時に、命令コードが主メモリからシステム・インターフェース101およびバス12を介して検索される。このコードが上述の通常データ経路を介して命令装置105に供給される。

【0073】命令コードは、図8に示すように、簡単なPowerPC命令を取り扱うデコード機能ブロック70、簡単なX86命令を取り扱うデコード機能ブロック71、複雑なPowerPC命令を取り扱うデコード機能ブロック72および複雑なX86命令を取り扱うデコード機能ブロック73に対して並列に供給される。ここに説明する例において「簡単な」命令とは、基本的な演算クラスに対してマッピングし、一つの実行装置によって取り扱うことができる命令をいう。例えば、ロード演算、記憶演算および単一算術演算はすべて簡単な命令である。この定義により、他すべての命令は「複雑」である。例えば、X86のリピート・ムーブ・ストリング(repeat movestring)またはPowerPCのロード・マルチプル・ワード(load multiple word)は、複雑な命令の例である。デコード機能70の出力、すなわちデコードされた簡単なPowerPC命令は、マルチプレクサ(MUX)74の一方の入力に供給される。デコード機能71の出力、すなわちデコードされた簡単なX86命令は、まず、変換装置75(例えば、テーブル・ルックアップROM)に供給され、この変換装置が、対応する簡単なPowerPC命令をMUX74の第二の入力に出力

する。デコード機能72および73の出力は、マルチプレクサ（MUX）76に供給され、このマルチプレクサの出力がマイクロコード読出し専用メモリ（ROM）77に供給される。

【0074】ROM77は、PowerPCおよびX86の両方の複雑なデコードされた命令のための命令のテーブルを有している。複雑なPowerPCのデコードされた命令の場合、ROM77は、多数の、簡単なPowerPCデコードされた命令を出力する。MUX76から出力される複雑なデコードされたX86命令が、ROM77中の対応する多数の簡単なPowerPC命令に対してマッピングされる。このように、MUX74およびROM77の出力は、一つ以上の簡単なPowerPC命令である。モード制御装置108（図1および6）からのQビットがマルチプレクサ74および76を制御して、デコード機能70、72および71、73によってそれぞれ出力されるPowerPCまたはX86のデコードされた命令のいずれかを選択させる。MUX74およびROM77の出力は、ORゲート79によって制御される第三のMUX78に供給される。ORゲート79は、「複雑な」命令がデコード機能72または73の一方によって検出された場合、そのデコード機能から「有効」出力を受ける。図示していないが、これらの「有効」信号はまた、Qビットによって修飾される。このように、ORゲートの出力は、複雑な命令と簡単な命令との間で、すなわち、ROM77の出力とMUX74の出力との間で選択を行う。

【0075】X86およびPowerPCの修飾モード（図7を参照）を準備するため、初期化ソフトウェアは以下の段階を実行する。

【0076】・省略時X86モードからPowerPCモードへの即時コンテキスト切換を実行するため、ハードウェア機能制御レジスタを1にセットする。

【0077】・PowerPC仮想環境を初期化する（すなわち、外部メモリ中に必要なページ・テーブルを準備し、BATおよびセグメント・レジスタを初期化する）。

【0078】・機械状態レジスタ（MSR）中の命令再配置（IR）ビットを1にセットすることにより、命令再配置を可能にして、ひいては命令アドレスの仮想変換を可能にする。

【0079】・アプリケーション起動を取り扱う適当なソフトウェア機構（例えばX86またはPowerPCコード）に対して分岐命令を実行する。

【0080】ハードウェア・リセットののち、プロセッサは、X86モードで実行する（省略時）。したがって、Qビットがモード制御装置108によって0にセットされ、ハードウェア機能制御レジスタもまた0に初期化される。初期化ソフトウェアは、統いて、コンテキスト切換を可能にするため、ハードウェア機構制御レジスタを1にセットすべきである。命令再配置はオフである（すなわちVビットが0である）ため、これはまた、モード制御装置108に対し、X86コードの実行からPowerPC

コードの実行へのコンテキスト切換を実行するよう強要する。機能制御レジスタ書き込みに続く次の命令は、PowerPC命令として実行される。

【0081】次に、初期化プロセスにおいて、ページ・テーブル52（図4）が準備され、命令再配置が可能になったならば（すなわち、MSR IRビットが1にセットされ、その結果、Vビットが1にセットされたならば）実効状態になる、修飾PowerPCモード（図7）を可能にするためのエントリが行われる。これもまた、PowerPCセグメントレジスタおよびBATレジスタをそれらの適当な値に初期化することを要する。そして、X86記述子テーブルを、X86アプリケーションによる使用に備えて初期化することになる。最後に、PowerPCのMSRレジスタ中のIRビットを1にセットし、それにより、Vビットを1にセットすることによって命令再配置が可能になるであろう。最後の命令は、最初のプログラムを開始する記憶場所への分岐命令となる。目標コードは、X86コードまたはPowerPCコードのいずれかであることができる。いずれであれ、そのコードは4KBブロックにおいて管理される。

【0082】分岐命令が実行すると、QおよびVの値は、Q=1（PowerPCコードを実行）およびV=1（命令再配置／仮想変換可能）になる。したがって、Qビットの次の状態が、モード制御装置108により、分岐命令の目標に対応するページ・テーブル項目からアクセスされたPビットの値から決定される。Pビットの値は、MMU103からモード制御装置108に提供されるものである。この時点で、ソフトウェア初期化が完了する。

【0083】初期化が完了したならば、MMU103がTLBルックアップを実行する。ルックアップの結果、ヒットし、Pビットが1であるならば、MMU103は、そのコードがX86コードであることを認知し、モード制御装置108に知らせ、ページ・モード制御ビットPによって状態を戻して、それにより、コンテキスト・モードに関してモード制御装置に指示を出す。この流れから理解されることは、入ってきた命令がMMU103中に位置するか、MMUに加えられるとき、その命令がMMU103をしてモード制御装置108のモードを切り換えるということである。換言するならば、MMU103のアドレス指定方式がモード制御装置108を駆動してモードを変更させるのである。しかし、入ってきた命令TLB中にない（ミス）ならば、ページ・テーブル・ウォークを実行して主メモリ・ルックアップ・テーブル中にその命令を探す。そこにもないならば、特殊な割込みが実施され、取り扱われる。

【0084】命令がページ・テーブル中にあると仮定すると、その命令はMMU103にロードされ、Pビットが現在のコンテキスト・モードと異なるならば、上記のようにMMU103はモード制御装置108のモードを切り換える。MMU103は常にモード制御装置のコンテキスト・

モードを打ち消す。この命令が次に実行するべき命令であるならば、モードの切換えが起こる。修飾PowerPCモードから修飾X86モードへの切換えは(図7)は、Pビット(P=1)によってモード制御装置108に知らせることによって実施される。そこで、モード制御装置108が、整数装置(I U)106および浮動小数点装置(F P U)107に対し、すべての命令をX86命令として解釈するよう伝えられる。さらに詳細には、アドレス変換機構ならびにセグメントおよびページ・テーブル編成機構がI U106中に存在する。モード制御装置108が、レジスタが何個あり、それらのレジスタがどのフォーマットを使用しているのかをI U106に伝える。モード制御装置108は、F P U107に対し、80ビットX86スタイルを使用すべきか、64ビットPowerPCスタイルを使用すべきかを伝え、それにより、同じレジスタ・ファイルの精度を制御する。

【0085】図8は、命令の流れが命令装置に進入し、それがデコードされる方法を示す。モード制御装置が送出し論理によってデコードされた命令の選択を制御する。図9は、図8の機能ブロック図に示す機能を実行する命令装置105の詳細なハードウェア・ブロック図である。図1の命令待ち行列1051は、図9に示す取出し整列装置801および命令待ち行列802を含む。取出し整列装置801は、命令取出しバスに接続され、入力として、命令キャッシュから取り込まれた命令および現在の命令アドレスを有している。取出し整列の要件はPowerPCアーキテクチャとX86アーキテクチャとで異なるため、モード制御装置108からのQビットを使用して、命令が、命令待ち行列802に移される前に、いかにして取出し整列ハードウェア801によって整列されるかを決定する。例えば、X86命令は、1~15個のバイトを含み、いかなるバイト境界上に配列されることもできるが、PowerPC命令は、常に長さ4バイトであり、したがって、常に4バイト境界上に配列される。取出し整列ハードウェア801は、命令取出しバスからの命令を、現在の命令の長さおよびアドレスに基づく適当な量だけシフトすることができなければならない。加えて、X86命令は長さが異なり、命令取出しバスのどこにでも配列されるため、X86命令は、一つの命令キャッシュ項目をあふれさせ、次の項目に入り込むおそれがある。アーキテクチャ・モード制御信号を使用して、取出し配列ハードウェア801が、連続する命令キャッシュ項目からの命令を併合し、命令待ち行列802の中に整列させるようにすることができる。

【0086】命令は、命令待ち行列802からX86命令デコーダ803およびPowerPC命令デコーダ804に転送される。X86命令デコーダ803は、図8のデコード機能71および73を実行し、PowerPCデコーダ804は、同図のデコード機能70および72を実行する。Qビットを使用して、図8を参照しながら説明したように、望みのアーキテクチ

ヤ・コンテキストに依存してX86命令デコーダ803またはPowerPC命令デコーダ804のいずれかを可能にする。これらのデコーダを使用して、すべての命令を、マイクロプロセッサによって実行がサポートされるところの共通の命令セットに変換する。例えば、X86の「ADD EAX, EB X」命令およびPowerPCの「add r8, r8, r11」命令は、いずれもそれぞれのデコーダにより、共通の「add r8, r8, r11」命令に変換される。より複雑な命令は、单一のより複雑な命令の機能を実行する簡単な一連の命令を生成するそれぞれのデコーダ803または804によって取り扱われる。例えば、PowerPC命令デコーダ804は、PowerPCのロード・マルチプル・ワード命令を個々のロードの連続としてエミュレートする。

【0087】モード制御装置108からのQビットはまた、図9を参照しながら説明したように、デコーダ803および804に対して直接的な効果を及ぼす。具体的には、PowerPCアーキテクチャにおいて、PowerPCソフトウェアがX86浮動小数点環境を管理し、X86記述子レジスタに対して読み書きすることを許す新たな命令が可能にされる。X86アーキテクチャにおいては、Qビットが、ページ変換を可能にし、ページ・ディレクトリ基底レジスタを初期化し、TLB中の項目を無効化するX86命令を不能にする。Qビットはまた、既存のPowerPC命令に対し、PowerPCソフトウェアが、メモリ中のどこかに位置するX86ソフトウェアに直接分岐することを許す拡張を可能にする。具体的には、すべてのPowerPC命令が4バイト境界上に位置しているため、PowerPC分岐命令中に記憶されたアドレスへと分岐する命令は、通常、レジスタの低位2ビットを無視する。しかし、X86命令はバイト整列されているため、PowerPC分岐は、1、2または3のバイト境界上にある命令に達することができない。Qビットは、前述の分岐アドレス・レジスタの低位2ビットを可能にし、それにより、PowerPCコードがバイト整列されたアドレスに分岐することを許すことにより、この問題を解消する。

【0088】Qビットの制御の下でデコーダ803および804によって生成される共通の命令は、実行リソース、例えば整数装置(I U)106および浮動小数点装置(F P U)107(図1)の動作に対して直接的な影響を及ぼす。X86デコーダ803は、G P R1062(図1)およびF P R1072(図1)中のレジスタのサブセットのみを使用する共通の命令を生成することができ、一方、PowerPCデコーダ804は、すべてのレジスタを使用する共通の命令を生成することができる。さらに、Qビットは二つのアーキテクチャのコンテキストを制御するが、一方のアーキテクチャによって使用される多数のレジスタが他方のアーキテクチャによってアクセスされることができる。具体的には、PowerPCソフトウェアは、すべてのX86レジスタに読み書きすることができ、X86ソフトウェアは、PowerPCのM S R、B A Tおよびデクレメンタ(d

ecrementer) ・レジスタに読み書きすることができる。

【0089】X86命令デコード803およびPowerPC命令デコード804から、デコードされた共通の形態の命令が、図8を参照しながら説明したように、Qビットによって制御される命令選択論理805を介して送出し論理806に移される。さらには、命令長の情報が次の命令取出しアドレス(NIFA)計算ブロック807に転送される。このNIFA計算ブロック807を使用して、命令キャッシュ104(図1)から取り出さなければならない次の命令のアドレスを計算する。これは、その入力として、現在の命令のアドレスを命令取出しバスから取り込み、命令長を二つのアーキテクチャ・デコード803および804から取り込み、二つの命令長の間で選択を行うアーキテクチャ・モード制御信号を取り込む。分岐処理装置(BPU)808(図1のBPU1054に相当)もまた、NIFA計算ブロック807への入力を有している。この入力は、分岐命令が次の命令取出しアドレスを分岐の目標に強いることを許す。

【0090】図6に示す論理によって生成されるモード切換えは、デコード803および804に入力される。この信号が、「モード切換え」命令と呼ばれる疑似命令として作用し、命令の流れの中で位置設定記号として働く。現在のプログラムのコードが完了すると、他方のアーキテクチャ・コンテキストへのモード切換えが生じる。分岐予測装置(BPU)803が、コード中のこの点を検出し、モード切換えを可能にして最終的に生じさせる遅延モード切換え(モード切換え')信号を出力する。この信号はまた、MUX67(図6)にもフィードバックされて、レジスタ66中のQビットの状態を切り換えるモード切換えを反映させる。

【0091】Qビットはまた、メモリ管理装置(MMU)103(図1)にも入力されて、どちらのアドレス変換機構がマイクロプロセッサによって用いられるかを制御する。オンチップMMU103は、PowerPCまたはX86のいずれかのページ・テーブル項目を共通のフォーマットで記憶することができる一つのページ・テーブル・キャッシュ、すなわち変換ルックアサイド・バッファ(TLB)を含む。Qビットの設定が、TLB項目がいかにしてプロセッサのハードウェアによって初期化されるか、そして、それらがアドレス変換中にどのように解釈されるかを決定する。図10は、マイクロプロセッサのTLB項目の共通のフォーマットならびにPowerPCおよびX86アーキテクチャのページ・テーブル項目がどのように中に記憶されているかを示す。

【0092】本発明においては、アーキテクチャ修飾制御ビットQが、両方のアーキテクチャによって使用されるアドレス変換機構を変更する。アーキテクチャ修飾制御ビットが1であるとき、オペレーティング・システムがPowerPCコードを含むメモリ・ページとX86コードを含むメモリ・ページとを区別することを可能にする、Po

werPCページング機構に対する拡張が可能になる。拡張のルートは、各PowerPCページ・テーブル項目中の、各ページをPowerPCページ(ビットが0にセット)またはX86ページ(ビットが1にセット)のいずれかとして定義するページ・モード制御ビットPからなる。このビットを使用して、上記で説明し、図7に表したようにして、アーキテクチャ・コンテキスト制御信号の値を駆動する。

【0093】命令がメモリから取り出されるとき、まず、そのアドレスが、図1に示すMMU103によって変換される。MMU103は、ページ・モード制御ビットPの値を含む変換されたアドレスをもつ状態ビットを戻す。ページ・モード制御ビットの値がアーキテクチャ修飾制御ビットの現在値に等しいならば、プロセッサは以前と同様に同じアーキテクチャで作動を続ける。しかし、ページ・モード制御ビットの値がアーキテクチャ修飾制御ビットと異なるならば、以前に取り出されたすべての命令が実行され、例外なしに完了されるまで、命令取出しおよびデコードが停止される。完了したならば、アーキテクチャ・モード制御信号の値が、ページ・モード制御ビットの値に一致するように変更され、アーキテクチャ・モード制御信号によって確立された新たなコンテキストの下で命令取出しおよびデコードが再開される。

【0094】PowerPC変換機構に対する機能強化およびX86機構に対して加えられる限定が、特定的に、X86アドレス変換をPowerPCアドレス変換に対してマッピングすることを許して、両方のアーキテクチャ用に書かれたソフトウェアを多重タスク処理システム中で作動させるためのより動的な環境を提供する。アーキテクチャ修飾制御ビットQが1にセットされると、PowerPCアドレス変換機構が「管理状態」になる。これが意味することは、X86セグメント変換が起こるが、X86ページ変換を実行する代わりに、PowerPCセグメントおよびページ変換が統合してPAを形成するということである。これが、一つのオペレーティング・システムがいずれのアーキテクチャ用に書かれたソフトウェアのアドレス変換をも管理することを許す。唯一の制限は、X86ソフトウェアがそれ自体のX86ページング関連の作業を実行することができないことである。

【0095】64ビットPowerPCの具現化は64ビット・アドレスを変換し、一方、今日定義されるX86アーキテクチャは32ビット・アドレスを生成する。本発明は、32ビット・レジスタ値を最終的な64ビット・アドレスの高位32ビットとして連結することにより、32ビットX86アドレスから64ビット・アドレスを生成するための手段を提供する。これが、32ビットX86アドレス空間を64ビット空間のどこかに位置づけることを許し、また、レジスタの値を動的に変化させることにより、オペレーティング・システムが多数のX86アドレス空間を管理することを

許す。32ビットの具現化においては、このレジスタ値は無視される（すなわち、実質的に0に強いられる）。

【0096】図11は、本発明による方法を使用して二つのアドレス変換機構をどのように併合するか、また、その処理のどこで32ビット・レジスタ値がX86アドレスと連結されて64ビット・アドレスを形成するのかを高レベルで示す。レジスタ1001が、X86論理アドレスを構成する32ビット・オフセットおよび16ビット・セレクタを保持する。このセレクタを使用して記述子テーブル1002をアドレス指定する。テーブル1002からのセグメント記述子が加算器1003中でオフセットと合わされて32ビットX86線形アドレスをレジスタ1004中に生成する。レジスタ1005中の32ビットX86基底アドレスが64ビットPowerPC実効アドレス・レジスタ1006の基底32ビットの中に読み込まれる。レジスタ1004中の32ビット線形アドレスがレジスタ1006中の32ビット基底アドレスと連結されて64ビットPowerPC実効アドレスを形成する。レジスタ1006からの有効セグメントIDを使用してセグメント・テーブル1007をアドレス指定して、図2を参照しながら説明したように、80ビットPowerPC仮想アドレスをレジスタ1008中に生成する。レジスタ1008の仮想セグメントIDを使用してページ・テーブル1009をアドレス指定して、図4を参照しながら説明したように、52ビットPowerPC実アドレスを生成する。

【0097】図1のメモリ管理装置103はまた、アーキテクチャ・コンテキスト制御信号の下、PowerPCおよびX86アーキテクチャで、ページングされたメモリ保護検査を実行する責任を負う。図12はPowerPCページ保護機構を示す。保護情報が三つのソースから収集される。すなわち、セグメント・テーブル項目1101（64ビットPowerPC）またはセグメント・レジスタ1101（32ビットPowerPC）中に見いだされるK<sub>s</sub>およびK<sub>p</sub>セグメント保護ビット、PowerPC機械状態レジスタ（MSR）1102中に見いだされるスーパバイザ／ユーザ・モード・ビット（PR）、そして、下寄りページ・テーブル項目1104中に見いだされるPPページ保護ビットである。保護キー1105は、K<sub>p</sub>セグメント保護ビットをMSR・PRスーパバイザ／ユーザ・モード・ビットとでAND演算し、その結果を、K<sub>s</sub>セグメント保護ビットとMSR・PRスーパバイザ／ユーザ・モード・ビットの否定との論理積とでOR演算することによって形成される。キー1105を使用して、メモリ管理装置103（図1）がページ保護PPビットの値を検査して、テーブル1106に示すような許容されるアクセスのタイプを決定する。

【0098】図13は、X86ページ保護機構が作動する方法を示す。保護情報が四つのソースから収集される。すなわち、現在のスタック・セグメント記述子1201の記述子特権レベル（しばしば現在の特権レベルまたはCPLと呼ぶ）、レジスタCR0（1202）からの書き込み保護ビットWP、ページ・テーブル項目1203からのユーザ／

スーパバイザ・ビットU/S、そして、同じくページ・テーブル項目1203からの読み／書きビットR/Wである。この情報を使用して、メモリ管理装置がテーブル1204に示すような検査を実行して、許容されるアクセスのタイプを決定する。

【0099】本発明においては、アーキテクチャ修飾機構ビットは、プロセッサがX86モードで作動しているときに使用される保護機構のみを変更する。具体的には、X86ページ変換がPowerPCページ変換によって取って代わられているため、X86ページ保護機構はPowerPCページ保護機構によって完全に取って代わられる。X86モードでは、修飾機構ビットがPowerPC MSR PRビットをしてX86 CPLの特権を反映させる。0、1または2のX86 CPLがMSR PRを0（スーパバイザ）の値に強要し、3のX86 CPLがMSR PRビットを1（ユーザ）の値に強要する。すると、上記のように保護キー1105（図11）が形成される。MSR PRビットをしてX86モードでCPLを追跡させることにより、X86スーパバイザ・コードをX86およびPowerPCユーザ・コードから保護することができる。オペレーティング・システムのソフトウェアは通常、スーパバイザ・レベルで作動するため、これが、好都合なところで、オペレーティング・システムの一部をX86コードで具現化することを許す。

【0100】図14は、PowerPCアーキテクチャのうち、割込みおよび例外の動作を制御する部分のブロック図である。機械状態レジスタ1301を使用して、EEビット1301によって外部割込みを可能にしたり不能にしたりし、また、IPビット1311によって物理メモリ中の割込みベクトル・テーブル1307の場所を決定する。レジスタSRR0（1302）を使用して、結果的に例外となつたか、割込みの場合に実行されていたであろう命令の実効アドレスを記録する。レジスタSRR1（1302）は、例外の特定の原因に関する状態情報ならびに割込みまたは例外の前のMSR1301中の特定のビットを含む。レジスタDAR1304は、データ関連の例外中の例外を引き起こしたデータ・オペランドの実効アドレスを保持する。レジスタDSISR905は、データ関連の例外の特定の原因に関する状態情報を含む。

【0101】割込みまたは例外がPowerPCアーキテクチャによって受け入れられるとき、割込み手順の場所は、割込みのタイプおよびMSR割込みプレフィックス（IP）ビット1311の値に依存する。MSR IPビット1311は、割込みベクトル・テーブル基底アドレス1306が0x0000000の値を有するのか、0xFFFF0000の値を有するのかを指定する。このアドレスが、タイプ割込みによって指定されるベクトル・テーブル1307へのオフセットに加えられて、割込み手順1309の物理アドレスを形成する。例えば、IVT基底アドレス1306が0xFFFF0000であり、データ記憶割込みが受け入れられるならば、割込み

手順1309の物理アドレスは0xFFFF00300になる。

【0102】図15は、割込み手順場所をX86アーキテクチャによって指定する二つの方法を示す。いずれの方法においても、割込み番号1401は、命令、外部的割込みまたは内部的例外のいずれかによって指定される。X86実モード（保護モードは不能になる）では、割込みベクトル・テーブル1402は普通、0x00000000の基底アドレスを有している。割込み手順は、割込み番号1401に4を掛け、それにより、割込みプロセッサに対する「遠い」ポインタを提供することによって位置づけられる。この「遠い」ポインタは、オフセットおよびセグメント値からなる。X86保護モード（アドレス変換は可能になる）では、割込み番号1401に8を掛けて、割込み記述子テーブル1403へのオフセットを出す。基準化された割込み番号1401によって参照される割込みゲートは、宛先コード・セグメント1405へのオフセットおよびセグメント・テーブル1406へのオフセットを含む。オフセットによってセグメント・テーブル1406中に指されるセグメント記述子1407は、宛先コード・セグメント1405の基底アドレスを含む。この基底アドレスが宛先コード・セグメント1405へのオフセットに加算されて、割込み手順1408の実効アドレスを形成する。

【0103】X86アーキテクチャにおいて割込みが受け入れられると、図16に示すように、特定の情報が割込み手順スタック上に記録される。これは、割込みを受けた手順のスタックポインタ（旧SS1501および旧ESP1502）と、割り込まれた命令へのポインタ（旧CS1504および旧EIP1505）と、エラー・コード1506と、割り込まれた命令の状態を含むFLAGS1503のコピーとからなる。加えて、ページ障害割込みが、CR2（1507）においてページ障害を生じさせた命令またはデータ・バイトのアドレスを記憶する。

【0104】PowerPCおよびX86の両アーキテクチャの割込みおよび例外は、図1の分岐処理装置（BPW）1054によって取り扱われる。アーキテクチャ・モード制御装置108からのアーキテクチャ・コンテキスト機構ビットが、二つの割込みおよび例外機構、すなわちPowerPCまたはX86のどちらがマイクロプロセッサによって使用されるかを決定する。

【0105】アーキテクチャ修飾機構ビットが可能になると、プロセッサによって遭遇される割込みおよび例外は、割込みまたは例外のタイプならびにアーキテクチャ・コンテキスト機構ビットの状態に依存して、PowerPCまたはX86アーキテクチャ型機構のいずれかによって取り扱われる。具体的には、アーキテクチャ・コンテキスト機構ビットの状態にかかわらず、すべての非同期的割込みがPowerPC割込み機構に向けられる。これは、オペレーティング・システムが、プロセッサが実行していることに関連がないかもしれない事象が起こったとき、そのような事象に対して一貫した制御ポイントを有すること

とを許すために行われる。

【0106】同期的例外は、一般に、アーキテクチャ・コンテキスト機構ビットによって定義されるアーキテクチャ型機構に向けられる。しかし、これは、（a）ページ変換から生じる形態の例外および（b）MMU内で生じるPowerPC保護検査から生じる形態の例外の場合には、真ではない。いずれの場合においても、アーキテクチャ・コンテキスト機構ビットの値にかかわらず、例外はPowerPC機構に向けられる。理由は、X86ページングが動かされないため、すべてのPowerPC MMU関連の例外をPowerPC機構に転送しなければならないからである。

【0107】一つの好ましい実施態様に関して本発明を説明したが、当業者であれば、請求の範囲の真髓および範囲において本発明に変更を加えうることを認識するであろう。

【0108】まとめとして、本発明の構成に関して以下の事項を開示する。

- （1）別個の命令セットおよびメモリ管理方式を有する第一および第二のアーキテクチャをサポートし、一つの多重タスク処理オペレーティング・システムの下で作動するプロセッサにおいて、前記第一のアーキテクチャの第一の命令セットの命令をデコードし、前記第二のアーキテクチャの第二の命令セットの命令を直接デコードし、前記第一の命令セットのデコードされた命令を前記第二の命令セットの一つ以上の命令に対してマッピングするための命令セット管理手段と、前記第一および第二のアーキテクチャについて仮想アドレスから実アドレスへのアドレス変換を実行するためのメモリ管理手段と、
- メモリから読み出されるプログラムのアーキテクチャ・コンテキストを、前記第一のアーキテクチャのコードまたは前記第二のアーキテクチャのコードのいずれかとして検出し、前記命令セット管理手段および前記メモリ管理手段を制御して、前記第一のアーキテクチャのアドレス変換と第二のアーキテクチャのアドレス変換との間で動的に切り換え、前記第二のアーキテクチャの、一つ以上のマッピングされてデコードされた命令または直接デコードされた命令を実行するための制御手段と、を含むことを特徴とするプロセッサ。
- （2）前記メモリ管理手段が、実効アドレスを仮想アドレスに変換する際に第一または第二のアーキテクチャ変換方法のどちらがメモリ管理装置によって使用されるかを制御するための、前記制御手段によって制御されるモード制御機構を含む上記（1）記載のプロセッサ。
- （3）前記モード制御機構が前記プロセッサの命令取出しおよびデコード機構を制御して、前記第一および第二のアーキテクチャの命令が、前記命令セット管理手段による適切なデコードのために取り出され、配列されるようとする上記（2）記載のプロセッサ。
- （4）前記メモリ管理装置が、前記第二のアーキテクチ

ヤのページ・テーブル項目からページ・モード制御ビットを読み出し、前記ページ・モード制御ビットが前記制御手段に供給されて、前記メモリ管理手段によるアドレス変換を制御する上記（3）記載のプロセッサ。

（5）前記制御手段が、プロセッサがどちらのアーキテクチャ・コンテキストの下で作動するかを制御するためのアーキテクチャ・コンテキスト制御機構であって、実効アドレスを仮想アドレスに変換する際に前記プロセッサの前記メモリ管理装置によって使用されるアーキテクチャ変換方法を制御し、さらに、前記プロセッサの命令取出しおよびデコード論理を制御し、さらに、プロセスおよび構築されたリソースの実行コンテキストを制御し、さらに、前記プロセッサの割込みおよび例外機構を制御するためのアーキテクチャ・コンテキスト制御機構と、一つのアドレス変換機構が、一方のアーキテクチャのアドレスをもう一方のアーキテクチャのアドレスの変換に対してマッピングすることを許容し、統合された割込みおよび例外機構が、割込みまたは例外が生じた際に実効中のアーキテクチャ・コンテキストにかかわりなく、非同期的な割込みおよびページ変換ならびの保護関連の例外を取り扱うことを許容する拡張および限定を前記二つのアーキテクチャに対して可能にするための修飾モード制御機構と、を含む上記（1）記載のプロセッサ。

（6）前記命令セット管理手段が、前記第一の命令セットの命令をデコードするための第一のデコード手段と、前記第二の命令セットの命令をデコードするための第二のデコード手段と、前記第一のデコード手段からのデコードされた命令を前記第二の命令セットの一つ以上のデコードされた命令に対してマッピングするためのマッピング手段と、前記マッピング手段からのデコードされた命令または前記第二のデコード手段からのデコードされた命令を選択するための、前記制御手段によって制御される選択手段と、を含む上記（1）記載のプロセッサ。

（7）前記第一および第二のデコード手段が前記第一および第二のアーキテクチャの簡単な命令をデコードし、簡単な命令が、基本的な演算クラスの中にマッピングし、一つの実行装置によって取り扱わることができる命令であり、前記命令管理手段がさらに、前記第一の命令セットの複雑な命令をデコードするための第三のデコード手段と、前記第二の命令セットの複雑な命令をデコードするための第四のデコード手段と、前記第三または第四のデコード手段からのデコードされた命令を選択するための、前記制御手段によって制御される第二の選択手段と、前記第三または第四のデコード手段からのデコードされた命令を前記第二の命令セットの多数の簡単な命令に対してマッピングするための、前記第二の選択手段の出力を受ける第二のマッピング手段と、複雑な命令がデコードされる場合には前記第二のマッピング手段の出力を選択し、簡単な命令がデコードされる場合には前

記第一の選択手段の出力を選択するための、前記第三または第四のデコード手段の一方からの有効な信号に応答する第三の選択手段と、をさらに含む上記（6）記載のプロセッサ。

（8）前記制御装置が、前記プロセッサ内のレジスタ中に記憶された、前記第二のアーキテクチャのアドレス変換を可能にするか不能にするかを決定する第一のビット、メモリ中の現在のページが前記第一のアーキテクチャのものか前記第二のアーキテクチャのものかを示す第二のビットおよびアーキテクチャ修飾ビットである第三のビットを含む複数のビットの状態に依存して、前記プロセッサが複数の状態の一つに入るよう制御するモード制御装置を含む上記（1）記載のプロセッサ。

（9）前記プロセッサが、主メモリから読み出される命令のページ・モードを検出し、メモリ中の現在のページが前記第一のアーキテクチャのものか前記第二のアーキテクチャのものかを前記第二のビットによって前記モード制御装置に知らせるメモリ管理装置を含む上記（8）記載のプロセッサ。

（10）前記モード制御装置が、機能制御レジスタをさらに含み、前記プロセッサの起動またはリセット状態に応答して、前記プロセッサを前記第一および第二のアーキテクチャにそれぞれ対応する前記第一または第二のモードのいずれかで初期化し、その後、前記機能制御レジスタ中のビットの状態がアーキテクチャ・コンテキスト間での動的な切換を可能にする上記（8）記載のプロセッサ。

（11）一つの多重タスク処理オペレーティング・システムの下で作動するプロセッサにおいて具現化される、二つの別個の命令セット・アーキテクチャをサポートする方法であって、ソフトウェアによって供給されるモード制御ビットに応答して実効アドレスを仮想アドレスに変換する際に第一および第二のアーキテクチャ変換方法のどちらがメモリ管理装置によって使用されるかを制御するステップと、プロセッサの命令取出しおよびデコード機構を制御して、二つの異なるアーキテクチャの命令がソフトウェアによって供給されるモード制御ビットに応答して適切にデコードされるようにするステップと、一方のアーキテクチャの変換をもう一方のアーキテクチャのそれに対してマッピングすることにより、前記二つの異なるアーキテクチャのアドレスを変換するステップと、多重タスク処理環境において、一方のアーキテクチャ用に書かれたアプリケーション・ソフトウェアからもう一方のアーキテクチャ用に書かれたアプリケーション・ソフトウェアに切り換えるステップと、を含むことを特徴とする方法。

（12）マイクロプロセッサの割込みおよび例外機構を制御するステップと、一つのアドレス変換機構が、第一のアーキテクチャのアドレスを第二のアーキテクチャの変換に対してマッピングすることによって第一のアーキ

テクチャのアドレスを変換することを許容し、統合された割込みおよび例外機構が、割込みまたは例外が生じた際に実効中のアーキテクチャ・コンテキストにかかわりなく、非同期的な割込みおよびページ変換ならびに保護関連の例外を取り扱うことを許容する拡張および限定を前記二つのアーキテクチャに対して可能にするステップと、命令が実行すべきところのアーキテクチャ・コンテキストを決定するステップと、をさらに含む上記（1）記載のプロセッサにおいて具現化される方法。

（13）二つの別個の命令セット・アーキテクチャをサポートし、一つの多重タスク処理オペレーティング・システムの下で作動するマイクロプロセッサと、前記二つのアーキテクチャ用のアプリケーション・ソフトウェアを記憶する外部メモリ・デバイスと、前記マイクロプロセッサを前記外部メモリ・デバイスに接続するシステム・バスとを含み、前記マイクロプロセッサが、前記システム・バスに接続された内部バスを有し、前記マイクロプロセッサが、前記第一のアーキテクチャの第一の命令セットの命令をデコードし、前記第二のアーキテクチャの第二の命令セットの命令を直接デコードし、第一の命令セットのデコードされた命令を前記第二の命令セットの一つ以上の命令に対してマッピングするための命令セット管理手段と、前記第一および第二のアーキテクチャについて仮想アドレスから実アドレスへのアドレス変換を実行するためのメモリ管理手段と、メモリから読み出されるプログラムのアーキテクチャ・コンテキストを、前記第一のアーキテクチャのコードまたは前記第二のアーキテクチャのコードのいずれかとして検出し、前記命令セット管理手段および前記メモリ管理手段を制御して、前記第一のアーキテクチャのアドレス変換と前記第二のアーキテクチャのアドレス変換との間で動的に切り替え、前記第二のアーキテクチャの、一つ以上のマッピングされてデコードされた命令または直接デコードされた命令を実行するための制御手段と、を含むことを特徴とするコンピュータ・システム。

（14）前記マイクロプロセッサの前記メモリ管理手段が、実効アドレスを仮想アドレスに変換する際に第一または第二のアーキテクチャ変換方法のどちらがメモリ管理装置によって使用されるかを制御するためのモード制御機構を含む上記（13）記載のコンピュータ・システム。

（15）前記モード制御機構が前記プロセッサの命令取出しおよびデコード機構を制御して、前記第一および第二のアーキテクチャの命令が、前記命令セット管理手段による適切なデコードのために取り出され、配列されるようにする上記（14）記載のコンピュータ・システム。

（16）前記メモリ管理装置が、前記第二のアーキテクチャのページ・テーブル項目からページ・モード制御ビットを読み出し、前記ページ・モード制御ビットが前記

制御手段に供給されて、前記メモリ管理手段によるアドレス変換を制御する上記（15）記載のコンピュータ・システム。

（17）前記制御手段が、プロセッサがどちらのアーキテクチャ・コンテキストの下で作動するかを制御するためのアーキテクチャ・コンテキスト制御機構であって、実効アドレスを仮想アドレスに変換する際に前記マイクロプロセッサのメモリ管理装置によって使用されるアーキテクチャ変換方法を制御し、さらに、前記マイクロプロセッサの命令取出しおよびデコード論理を制御し、さらに、プロセスおよび構築されたリソースの実行コンテキストを制御し、さらに、前記マイクロプロセッサの割込みおよび例外機構を制御するためのアーキテクチャ・コンテキスト制御機構と、一つのアドレス変換機構が、一方のアーキテクチャのアドレスをもう一方のアーキテクチャのアドレス変換に対してマッピングすることを許容し、統合された割込みおよび例外機構が、割込みまたは例外が生じた際に実効中のアーキテクチャ・コンテキストにかかわりなく、非同期的な割込みおよびページ変換ならびに保護関連の例外を取り扱うことを許容する拡張および限定を前記二つのアーキテクチャに対して可能にするための修飾モード制御機構と、を含む上記（1）記載のコンピュータ・システム。

（18）前記マイクロプロセッサの前記命令セット管理手段が、前記第一の命令セットの命令をデコードするための第一のデコード手段と、前記第二の命令セットの命令をデコードするための第二のデコード手段と、前記第一のデコード手段からのデコードされた命令を前記第二の命令セットの一つ以上のデコードされた命令に対してマッピングするためのマッピング手段と、前記マッピング手段からのデコードされた命令または前記第二のデコード手段からのデコードされた命令を選択するための、前記制御手段によって制御される選択手段と、を含む上記（13）記載のコンピュータ・システム。

（19）前記第一および第二のデコード手段が前記第一および第二のアーキテクチャの簡単な命令をデコードし、簡単な命令が、基本的な演算クラスの中にマッピングし、一つの実行装置によって取り扱わることができるものであり、前記命令管理手段がさらに、前記第一の命令セットの複雑な命令をデコードするための第三のデコード手段と、前記第二の命令セットの複雑な命令をデコードするための第四のデコード手段と、前記第三または第四のデコード手段からのデコードされた命令を選択するための、前記制御手段によって制御される第二の選択手段と、前記第三または第四のデコード手段からのデコードされた命令を前記第二の命令セットの多数の簡単な命令に対してマッピングするための、前記第二の選択手段の出力を受ける第二のマッピング手段と、複雑な命令がデコードされる場合には前記第二のマッピング手段の出力を選択し、簡単な命令がデコードされる場合には

（20）前記第一および第二のデコード手段が前記第一および第二のアーキテクチャの簡単な命令をデコードし、簡単な命令が、基本的な演算クラスの中にマッピングし、一つの実行装置によって取り扱わることができるものであり、前記命令管理手段がさらに、前記第一の命令セットの複雑な命令をデコードするための第三のデコード手段と、前記第二の命令セットの複雑な命令をデコードするための第四のデコード手段と、前記第三または第四のデコード手段からのデコードされた命令を選択するための、前記制御手段によって制御される第二の選択手段と、前記第三または第四のデコード手段からのデコードされた命令を前記第二の命令セットの多数の簡単な命令に対してマッピングするための、前記第二の選択手段の出力を受ける第二のマッピング手段と、複雑な命令がデコードされる場合には前記第二のマッピング手段の出力を選択し、簡単な命令がデコードされる場合には

前記第一の選択手段の出力を選択するための、前記第三または第四のデコード手段の一方からの有効な信号に応答する第三の選択手段と、を含む上記(18)記載のコンピュータ・システム。

(20) 前記マイクロプロセッサの前記制御手段が、前記プロセッサ内のレジスタ中に記憶された、前記第二のアーキテクチャのアドレス変換を可能にするか不能にするかを決定する第一のビット、メモリ中の現在のページが前記第一のアーキテクチャのものか前記第二のアーキテクチャのものかを示す第二のビットおよびアーキテクチャ修飾ビットである第三のビットを含む複数のビットの状態に依存して、前記プロセッサが複数の状態の一つに入るよう制御するモード制御装置を含む上記(13)記載のコンピュータ・システム。

(21) 前記プロセッサが、主メモリから読み出される命令のページ・モードを検出し、メモリ中の現在のページが前記第一のアーキテクチャのものか前記第二のアーキテクチャのものかを前記第二のビットによって前記モード制御装置に知らせるメモリ管理装置を含む上記20記載のコンピュータ・システム。

(22) 前記モード制御装置が、機能制御レジスタをさらに含み、前記プロセッサの起動またはリセット状態に応答して、前記プロセッサを前記第一および第二のアーキテクチャにそれぞれ対応する前記第一または第二のモードのいずれかで初期化し、その後、前記機能制御レジスタ中のビットの状態がアーキテクチャ・コンテキスト間での動的な切換えを可能にする上記20記載のコンピュータ・システム。

(23) 前記マイクロプロセッサが、サポートされる二つのアーキテクチャに共通のフォーマットを使用して具現化される一つのメモリ管理装置を有している上記13記載のコンピュータ・システム。

(24) 前記マイクロプロセッサが、前記サポートされる二つのアーキテクチャによって共用される一つの命令取出し機構と、別々の命令デコード機構とを有している上記13記載のコンピュータ・システム。

(25) 前記マイクロプロセッサのすべての実行リソースが前記サポートされる二つのアーキテクチャに共通である上記13記載のコンピュータ・システム。

(26) 別個の命令セットおよびメモリ管理方式を有する第一および第二のアーキテクチャをサポートするプロセッサにおいて、前記第一および第二のアーキテクチャ用に書かれたアプリケーション・プログラムを記憶する外部メモリに接続するためのシステム・インターフェースと、前記第二のアーキテクチャのページ・テーブル項目からページ・モード制御ビットを読み出すための、前記システム・インターフェースに接続されたメモリ管理装置と、第一の命令セットの命令をデコードし、デコードされた命令を第二の命令セットの一つ以上のデコードされた命令に対してマッピングするための第一のデコード手

段と、第二の命令セットの命令をデコードするための第二のデコード手段と、前記第一または第二のデコード手段によってデコードされた命令を選択するための選択手段とを含む取出しおよびデコード機構を含む命令装置と、第一および第二のアーキテクチャ・モードのどちらを可能にするかに依存してアクセスすることができる複数のレジスタを有する、前記命令装置からのデコードされた命令を受信し、実行するために接続された実行装置と、前記命令装置および前記実行装置に接続されたモード制御装置とを含み、前記メモリ管理装置によって読み出される前記ページ・モード制御ビットが前記モード制御装置に供給され、前記第一または第二のアーキテクチャ・モードのいずれかを可能にしてアドレス変換を制御し、前記プロセッサの前記命令取出しおよびデコード機構を制御して、前記第一および第二のアーキテクチャの命令が適切なデコードに備えて取り出され、配列されるようにすることを特徴とするプロセッサ。

(27) 前記モード制御装置が、前記プロセッサ内のレジスタ中に記憶された、前記第二のアーキテクチャのアドレス変換を可能にするか不能にするかを決定する第一のビット、メモリ中の現在のページが前記第一のアーキテクチャのものか前記第二のアーキテクチャのものかを示す第二のビットおよびアーキテクチャ修飾ビットである第三のビットを含む複数のビットの状態に依存して、前記プロセッサが複数の状態の一つに入るよう制御する上記26記載のプロセッサ。

(28) 前記モード制御装置が、機能制御レジスタをさらに含み、前記プロセッサの起動またはリセット状態に応答して、前記プロセッサを前記第一および第二のアーキテクチャにそれぞれ対応する前記第一または第二のモードのいずれかで初期化し、その後、前記機能制御レジスタ中のビットの状態がアーキテクチャ・コンテキスト間での動的な切換えを可能にする上記27記載のプロセッサ。

#### 【図面の簡単な説明】

【図1】 本発明を具現化することができるマイクロプロセッサのブロック図である。

【図2】 PowerPCアーキテクチャにおける実効アドレスから仮想アドレスへの変換(セグメント化)を示すブロック図である。

【図3】 X86アーキテクチャにおける実効アドレスから仮想アドレスへの変換(セグメント化)を示すブロック図である。

【図4】 PowerPCアーキテクチャにおける仮想アドレスから物理アドレスへの変換(ページング)を示すブロック図である。

【図5】 X86アーキテクチャにおける仮想アドレスから物理アドレスへの変換(ページング)を示すブロック図である。

50 【図6】 図1の例示的なモード制御装置の関連の論理を

示す論理図である。

【図 7】アーキテクチャ・モード制御装置がアーキテクチャ・コンテキスト制御を生成する方法を示す状態図である。

【図 8】マイクロプロセッサの命令装置のデータの流れを示す高レベルブロック図である。

【図 9】マイクロプロセッサの命令装置のブロック図である。

【図 10】変換ルックアサイド・バッファ (TLB) フォーマットをPowerPCおよびX86のページのテーブル項目について対比させるブロック図である。

【図 11】本発明にしたがってX86アドレス変換がPowerPCアドレス変換にマッピングされることを示すブロック図である。

【図 12】PowerPCのページングされた保護検査規則を示すテーブルおよびブロック図のセットである。

【図 13】X86のページングされた保護検査規則を示すテーブルおよびブロック図のセットである。

【図 14】PowerPCの割込み状態および制御レジスタならびに割込みベクトル・テーブルを示すブロック図である。

【図 15】X86の実モードおよび保護モードの割込みベクトル・テーブルを示すブロック図である。

【図 16】X86の割込み状態および制御レジスタならびに割込みスタックを示すブロック図である。

【符号の説明】

|     |               |
|-----|---------------|
| 10  | マイクロプロセッサ     |
| 10  | システム・バス       |
| 101 | システム・インターフェース |
| 102 | メモリ装置         |
| 103 | メモリ管理装置       |
| 104 | キャッシュ         |
| 105 | 命令装置          |
| 106 | 整数装置          |
| 107 | 浮動小数点装置       |
| 108 | モード制御装置       |

【図 2】



【図 5】



【図 4】



【図 1】



【図 6】



【図 16】



【図 3】



【図 10】



【図 11】



【図 8】



【図 9】



【図 12】

|       |    |                                     |        |
|-------|----|-------------------------------------|--------|
| 1101～ |    | セグメント・テーブル項目<br>一または一<br>セグメント・レジスタ |        |
| 1102～ |    | MSR                                 |        |
| 1103～ |    | 上寄りページ・テーブル項目                       |        |
| 1104～ |    | 下寄りページ・テーブル項目                       |        |
| 1105～ | キー | ←( Ks & MSR.PR )   ( Ks & -MSR.PR ) |        |
| 1106  | キー | PP                                  | アクセス許可 |
|       | 0  | 00                                  | 読み書き   |
|       | 0  | 01                                  | 読み書き   |
|       | 0  | 10                                  | 読み書き   |
|       | 0  | 11                                  | 読み出し専用 |
|       | 1  | 00                                  | なし     |
|       | 1  | 01                                  | 読み出し専用 |
|       | 1  | 10                                  | 読み書き   |
|       | 1  | 11                                  | 読み出し専用 |

【図 14】

|       |  |       |
|-------|--|-------|
| 1301～ |  | MSR   |
| 1302～ |  | SRRO  |
| 1303～ |  | SRRI  |
| 1304～ |  | DAR   |
| 1305～ |  | DSISR |



【図 13】

|       |    |                      |     |     |        |
|-------|----|----------------------|-----|-----|--------|
| 1201～ |    | 現在のスタック・<br>セグメント記述子 |     |     |        |
| 1202～ |    | CRO                  |     |     |        |
| 1203～ |    | ページ・テーブル項目           |     |     |        |
| 1204～ | WP | CPL                  | U/S | R/W | アクセス   |
|       | 0  | ユーザ                  | 0   | 0   | 読み出し専用 |
|       | 0  | ユーザ                  | 0   | 1   | R/W    |
|       | 0  | ユーザ                  | 1   | 0   | なし     |
|       | 0  | ユーザ                  | 1   | 1   | なし     |
|       | 0  | スーパバイザ               | 0   | 0   | R/W    |
|       | 0  | スーパバイザ               | 0   | 1   | R/W    |
|       | 0  | スーパバイザ               | 1   | 0   | 読み出し専用 |
|       | 0  | スーパバイザ               | 1   | 1   | R/W    |
|       | 1  | ユーザ                  | 0   | 0   | 読み出し専用 |
|       | 1  | ユーザ                  | 0   | 1   | R/W    |
|       | 1  | ユーザ                  | 1   | 0   | なし     |
|       | 1  | ユーザ                  | 1   | 1   | なし     |
|       | 1  | スーパバイザ               | 0   | 0   | 読み出し専用 |
|       | 1  | スーパバイザ               | 0   | 1   | R/W    |
|       | 1  | スーパバイザ               | 1   | 0   | 読み出し専用 |
|       | 1  | スーパバイザ               | 1   | 1   | R/W    |

【図 15】



フロントページの続き

(72)発明者 ステファン・ダブル・マヒン  
アメリカ合衆国05489、ヴァーモント  
州アンダーヒル スティーブンスビル・ロ  
ード アールアールワン ボックス 13  
95

(72)発明者 ジョン・ジェイ・ヴァーグヴィスト  
アメリカ合衆国05495、ヴァーモント  
州ウィルストン メットカーフ・ドライブ  
114

**This Page is Inserted by IFW Indexing and Scanning  
Operations and is not part of the Official Record**

## **BEST AVAILABLE IMAGES**

Defective images within this document are accurate representations of the original documents submitted by the applicant.

Defects in the images include but are not limited to the items checked:

- BLACK BORDERS**
- IMAGE CUT OFF AT TOP, BOTTOM OR SIDES**
- FADED TEXT OR DRAWING**
- BLURRED OR ILLEGIBLE TEXT OR DRAWING**
- SKEWED/SLANTED IMAGES**
- COLOR OR BLACK AND WHITE PHOTOGRAPHS**
- GRAY SCALE DOCUMENTS**
- LINES OR MARKS ON ORIGINAL DOCUMENT**
- REFERENCE(S) OR EXHIBIT(S) SUBMITTED ARE POOR QUALITY**
- OTHER:** \_\_\_\_\_

**IMAGES ARE BEST AVAILABLE COPY.**

**As rescanning these documents will not correct the image problems checked, please do not report these problems to the IFW Image Problem Mailbox.**